mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-11-09 13:12:37 -05:00
Button queue handling is split from main button driver
First half of https://gerrit.rockbox.org/r/c/rockbox/+/570 Change-Id: Icc64dfd8194c18f69564ed5f8bf7dd70a4330eb9
This commit is contained in:
parent
5954a2fd48
commit
da9d67a0fe
30 changed files with 266 additions and 221 deletions
|
|
@ -163,9 +163,9 @@ static void scrollwheel(unsigned int wheel_value)
|
|||
|
||||
last_wheel_post = time;
|
||||
|
||||
if (queue_empty(&button_queue))
|
||||
if (button_queue_empty())
|
||||
{
|
||||
queue_post(&button_queue, btn, wheel_fast_mode |
|
||||
button_queue_post(btn, wheel_fast_mode |
|
||||
(wheel_delta << 24) | wheel_velocity*360/WHEELCLICKS_PER_ROTATION);
|
||||
/* message posted - reset delta and poke backlight on*/
|
||||
wheel_delta = 1;
|
||||
|
|
|
|||
|
|
@ -105,12 +105,12 @@ void scrollwheel(unsigned int wheel_value)
|
|||
/* the wheel is more reliable if we don't send every change,
|
||||
* every WHEEL_COUNTER_DIVth is basically one "physical click"
|
||||
* which should make up 1 item in lists */
|
||||
if (++counter >= WHEEL_COUNTER_DIV && queue_empty(&button_queue))
|
||||
if (++counter >= WHEEL_COUNTER_DIV && button_queue_empty())
|
||||
{
|
||||
buttonlight_on();
|
||||
backlight_on();
|
||||
reset_poweroff_timer();
|
||||
queue_post(&button_queue, btn, ((wheel_delta+1)<<24));
|
||||
button_queue_post(btn, ((wheel_delta+1)<<24));
|
||||
/* message posted - reset count and remember post */
|
||||
counter = 0;
|
||||
last_wheel_post = current_tick;
|
||||
|
|
|
|||
|
|
@ -159,7 +159,7 @@ static void handle_scroll_wheel(int new_scroll)
|
|||
wheel_velocity = (7*wheel_velocity + v) / 8;
|
||||
}
|
||||
|
||||
if (queue_empty(&button_queue)) {
|
||||
if (button_queue_empty()) {
|
||||
int key = wheel_keycode;
|
||||
|
||||
if (v >= WHEEL_REPEAT_VELOCITY && prev_keypost == key) {
|
||||
|
|
@ -171,7 +171,7 @@ static void handle_scroll_wheel(int new_scroll)
|
|||
prev_keypost = wheel_keycode;
|
||||
|
||||
/* post wheel keycode with wheel data */
|
||||
queue_post(&button_queue, key,
|
||||
button_queue_post(key,
|
||||
(wheel_velocity >= WHEEL_ACCEL_START ? (1ul << 31) : 0)
|
||||
| wheel_delta | wheel_velocity);
|
||||
/* message posted - reset delta */
|
||||
|
|
|
|||
|
|
@ -223,7 +223,7 @@ static inline int ipod_4g_button_read(void)
|
|||
if (send_events)
|
||||
#endif
|
||||
/* The queue should have no other events when scrolling */
|
||||
if (queue_empty(&button_queue))
|
||||
if (button_queue_empty())
|
||||
{
|
||||
/* each WHEEL_SENSITIVITY clicks = scrolling 1 item */
|
||||
accumulated_wheel_delta /= WHEEL_SENSITIVITY;
|
||||
|
|
@ -232,11 +232,11 @@ static inline int ipod_4g_button_read(void)
|
|||
/* always use acceleration mode (1<<31) */
|
||||
/* always set message post count to (1<<24) for iPod */
|
||||
/* this way the scrolling is always calculated from wheel_velocity */
|
||||
queue_post(&button_queue, wheel_keycode | repeat,
|
||||
button_queue_post(wheel_keycode | repeat,
|
||||
(1<<31) | (1 << 24) | wheel_velocity);
|
||||
|
||||
#else
|
||||
queue_post(&button_queue, wheel_keycode | repeat,
|
||||
button_queue_post(wheel_keycode | repeat,
|
||||
(accumulated_wheel_delta << 16) | new_wheel_value);
|
||||
#endif
|
||||
accumulated_wheel_delta = 0;
|
||||
|
|
|
|||
|
|
@ -151,7 +151,7 @@ static void handle_scroll_wheel(int new_scroll)
|
|||
wheel_velocity = (7*wheel_velocity + v) / 8;
|
||||
}
|
||||
|
||||
if (queue_empty(&button_queue)) {
|
||||
if (button_queue_empty()) {
|
||||
int key = wheel_keycode;
|
||||
|
||||
if (v >= WHEEL_REPEAT_VELOCITY && prev_keypost == key) {
|
||||
|
|
@ -163,7 +163,7 @@ static void handle_scroll_wheel(int new_scroll)
|
|||
prev_keypost = wheel_keycode;
|
||||
|
||||
/* post wheel keycode with wheel data */
|
||||
queue_post(&button_queue, key,
|
||||
button_queue_post(key,
|
||||
(wheel_velocity >= WHEEL_ACCEL_START ? (1ul << 31) : 0)
|
||||
| wheel_delta | wheel_velocity);
|
||||
/* message posted - reset delta */
|
||||
|
|
|
|||
|
|
@ -126,7 +126,7 @@ int button_read_device(void)
|
|||
/* Scrollstrip direct button post - much better response */
|
||||
if ((buttons==BUTTON_UP) || (buttons==BUTTON_DOWN))
|
||||
{
|
||||
queue_post(&button_queue,buttons|repeat,0);
|
||||
button_queue_post(buttons|repeat,0);
|
||||
backlight_on();
|
||||
buttonlight_on();
|
||||
reset_poweroff_timer();
|
||||
|
|
|
|||
|
|
@ -144,7 +144,7 @@ int button_read_device(void)
|
|||
/* Scrollstrip direct button post - much better response */
|
||||
if ((btn == BUTTON_UP) || (btn == BUTTON_DOWN))
|
||||
{
|
||||
queue_post(&button_queue,btn|repeat,0);
|
||||
button_queue_post(btn|repeat,0);
|
||||
backlight_on();
|
||||
buttonlight_on();
|
||||
reset_poweroff_timer();
|
||||
|
|
|
|||
|
|
@ -133,12 +133,12 @@ int button_read_device(void)
|
|||
if ((~GPIOA_INPUT_VAL & 0x40) != rec_switch)
|
||||
{
|
||||
if (rec_switch) {
|
||||
queue_post(&button_queue,BUTTON_REC_SW_OFF,0);
|
||||
queue_post(&button_queue,BUTTON_REC_SW_OFF|BUTTON_REL,0);
|
||||
button_queue_post(BUTTON_REC_SW_OFF,0);
|
||||
button_queue_post(BUTTON_REC_SW_OFF|BUTTON_REL,0);
|
||||
}
|
||||
else {
|
||||
queue_post(&button_queue,BUTTON_REC_SW_ON,0);
|
||||
queue_post(&button_queue,BUTTON_REC_SW_ON|BUTTON_REL,0);
|
||||
button_queue_post(BUTTON_REC_SW_ON,0);
|
||||
button_queue_post(BUTTON_REC_SW_ON|BUTTON_REL,0);
|
||||
}
|
||||
rec_switch = ~GPIOA_INPUT_VAL & 0x40;
|
||||
backlight_on();
|
||||
|
|
|
|||
|
|
@ -246,7 +246,7 @@ void clickwheel_int(void)
|
|||
|
||||
count = 0;
|
||||
|
||||
if (queue_empty(&button_queue))
|
||||
if (button_queue_empty())
|
||||
{
|
||||
/* Post wheel keycode with wheel data */
|
||||
int key = keycode;
|
||||
|
|
@ -260,7 +260,7 @@ void clickwheel_int(void)
|
|||
|
||||
prev_keypost = keycode;
|
||||
|
||||
queue_post(&button_queue, key, (fast_mode << 31) | delta | velocity);
|
||||
button_queue_post(key, (fast_mode << 31) | delta | velocity);
|
||||
/* Message posted - reset delta */
|
||||
delta = 1ul << 24;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -195,7 +195,7 @@ static void handle_wheel(uint8_t wheel)
|
|||
}
|
||||
|
||||
/* TODO: take velocity into account */
|
||||
if (queue_empty(&button_queue))
|
||||
if (button_queue_empty())
|
||||
{
|
||||
if (prev_key_post == key)
|
||||
{
|
||||
|
|
@ -204,7 +204,7 @@ static void handle_wheel(uint8_t wheel)
|
|||
|
||||
/* Post directly, don't update btn as avr doesn't give
|
||||
interrupt on scroll stop */
|
||||
queue_post(&button_queue, key, wheel_delta);
|
||||
button_queue_post(key, wheel_delta);
|
||||
|
||||
wheel_delta = 1ul << 24;
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue