diff options
Diffstat (limited to 'firmware/target/arm/iriver')
-rwxr-xr-x | firmware/target/arm/iriver/h10/adc-h10.c | 4 | ||||
-rw-r--r-- | firmware/target/arm/iriver/h10/adc-target.h | 2 | ||||
-rw-r--r-- | firmware/target/arm/iriver/h10/button-h10.c | 47 | ||||
-rw-r--r-- | firmware/target/arm/iriver/h10/button-target.h | 16 |
4 files changed, 59 insertions, 10 deletions
diff --git a/firmware/target/arm/iriver/h10/adc-h10.c b/firmware/target/arm/iriver/h10/adc-h10.c index 0dc0e8aee5..cf937851b9 100755 --- a/firmware/target/arm/iriver/h10/adc-h10.c +++ b/firmware/target/arm/iriver/h10/adc-h10.c @@ -69,7 +69,7 @@ static void adc_tick(void) adc_counter = 0; adc_scan(ADC_BATTERY); adc_scan(ADC_UNKNOWN_1); - adc_scan(ADC_UNKNOWN_2); + adc_scan(ADC_REMOTE); adc_scan(ADC_SCROLLPAD); } } @@ -85,7 +85,7 @@ void adc_init(void) /* Force a scan of all channels to get initial values */ adc_scan(ADC_BATTERY); adc_scan(ADC_UNKNOWN_1); - adc_scan(ADC_UNKNOWN_2); + adc_scan(ADC_REMOTE); adc_scan(ADC_SCROLLPAD); tick_add_task(adc_tick); diff --git a/firmware/target/arm/iriver/h10/adc-target.h b/firmware/target/arm/iriver/h10/adc-target.h index 3aab373290..741c293baa 100644 --- a/firmware/target/arm/iriver/h10/adc-target.h +++ b/firmware/target/arm/iriver/h10/adc-target.h @@ -32,7 +32,7 @@ #define ADC_BATTERY 0 #define ADC_UNKNOWN_1 1 -#define ADC_UNKNOWN_2 2 +#define ADC_REMOTE 2 #define ADC_SCROLLPAD 3 #define ADC_UNREG_POWER ADC_BATTERY /* For compatibility */ diff --git a/firmware/target/arm/iriver/h10/button-h10.c b/firmware/target/arm/iriver/h10/button-h10.c index 6980948336..520a616b4c 100644 --- a/firmware/target/arm/iriver/h10/button-h10.c +++ b/firmware/target/arm/iriver/h10/button-h10.c @@ -50,15 +50,23 @@ bool button_hold(void) return (GPIOA_INPUT_VAL & 0x4)?false:true; } +bool remote_button_hold(void) +{ + return adc_scan(ADC_REMOTE) < 0x17; +} + /* * Get button pressed from hardware */ int button_read_device(void) { int btn = BUTTON_NONE; + int data; unsigned char state; static bool hold_button = false; + static bool remote_hold_button = false; bool hold_button_old; + bool remote_hold_button_old; /* Hold */ hold_button_old = hold_button; @@ -72,6 +80,7 @@ int button_read_device(void) } #endif + /* device buttons */ if (!hold_button) { /* Read normal buttons */ @@ -88,14 +97,12 @@ int button_read_device(void) /* Read scroller */ if ( GPIOD_INPUT_VAL & 0x20 ) { - int scroll_pos; - GPIOD_OUTPUT_VAL &=~ 0x40; udelay(50); - scroll_pos = adc_scan(ADC_SCROLLPAD); + data = adc_scan(ADC_SCROLLPAD); GPIOD_OUTPUT_VAL |= 0x40; - if(scroll_pos < 0x210) + if(data < 0x210) { btn |= BUTTON_SCROLL_DOWN; } else { @@ -104,5 +111,37 @@ int button_read_device(void) } } + /* remote buttons */ + remote_hold_button_old = remote_hold_button; + + data = adc_scan(ADC_REMOTE); + remote_hold_button = data < 0x17; + +#ifndef BOOTLOADER + if (remote_hold_button != remote_hold_button_old) + backlight_hold_changed(remote_hold_button); +#endif + + if(!remote_hold_button) + { + if (data < 0x3FF) + { + if(data < 0x1F0) + if(data < 0x141) + btn |= BUTTON_RC_FF; + else + btn |= BUTTON_RC_REW; + else + if(data < 0x2BC) + btn |= BUTTON_RC_VOL_DOWN; + else + btn |= BUTTON_RC_VOL_UP; + } + } + + /* remote play button should be dead if hold */ + if (!remote_hold_button && !(GPIOA_INPUT_VAL & 0x1)) + btn |= BUTTON_RC_PLAY; + return btn; } diff --git a/firmware/target/arm/iriver/h10/button-target.h b/firmware/target/arm/iriver/h10/button-target.h index 48aa10c124..4831aa4efb 100644 --- a/firmware/target/arm/iriver/h10/button-target.h +++ b/firmware/target/arm/iriver/h10/button-target.h @@ -26,8 +26,10 @@ #include "config.h" #define HAS_BUTTON_HOLD +#define HAS_REMOTE_BUTTON_HOLD bool button_hold(void); +bool remote_button_hold(void); void button_init_device(void); int button_read_device(void); @@ -49,10 +51,18 @@ int button_read_device(void); #define BUTTON_MAIN (BUTTON_POWER|BUTTON_O|BUTTON_BACK|BUTTON_REW\ |BUTTON_PLAY|BUTTON_FF) - /* No Remote control */ -#define BUTTON_REMOTE 0 + /* Remote control's buttons */ +#define BUTTON_RC_REW 0x00080000 +#define BUTTON_RC_PLAY 0x00100000 +#define BUTTON_RC_FF 0x00200000 +#define BUTTON_RC_VOL_UP 0x00400000 +#define BUTTON_RC_VOL_DOWN 0x00800000 -#define POWEROFF_BUTTON BUTTON_POWER +#define BUTTON_REMOTE (BUTTON_RC_PLAY|BUTTON_RC_VOL_UP|BUTTON_RC_VOL_DOWN\ + |BUTTON_RC_REW|BUTTON_RC_FF) + +#define POWEROFF_BUTTON BUTTON_POWER +#define RC_POWEROFF_BUTTON BUTTON_RC_PLAY #define POWEROFF_COUNT 10 #endif /* _BUTTON_TARGET_H_ */ |