summaryrefslogtreecommitdiff
path: root/firmware/2lib/2ui_screens.c
diff options
context:
space:
mode:
Diffstat (limited to 'firmware/2lib/2ui_screens.c')
-rw-r--r--firmware/2lib/2ui_screens.c91
1 files changed, 22 insertions, 69 deletions
diff --git a/firmware/2lib/2ui_screens.c b/firmware/2lib/2ui_screens.c
index b8ff3a5c..e0a6d599 100644
--- a/firmware/2lib/2ui_screens.c
+++ b/firmware/2lib/2ui_screens.c
@@ -53,60 +53,45 @@ static vb2_error_t power_off_action(struct vb2_ui_context *ui)
/******************************************************************************/
/* Functions used for log screens */
+/*
+ * TODO(b/163301076): Reconsider the functionalities of page up/down buttons
+ * when reaching the start/end of the log.
+ */
static vb2_error_t log_page_init(struct vb2_ui_context *ui,
- uint32_t page_up_item,
uint32_t page_down_item,
uint32_t alternate_item)
{
ui->state->current_page = 0;
- if (ui->state->page_count == 1) {
- ui->state->disabled_item_mask |= 1 << page_up_item;
- ui->state->disabled_item_mask |= 1 << page_down_item;
+ if (ui->state->page_count == 1)
ui->state->selected_item = alternate_item;
- } else {
- ui->state->disabled_item_mask |= 1 << page_up_item;
+ else
ui->state->selected_item = page_down_item;
- }
return VB2_REQUEST_UI_CONTINUE;
}
-static vb2_error_t log_page_prev(struct vb2_ui_context *ui,
- uint32_t page_up_item,
- uint32_t page_down_item)
+static vb2_error_t log_page_prev_action(struct vb2_ui_context *ui)
{
- if (ui->state->current_page == 0)
- return VB2_REQUEST_UI_CONTINUE;
- ui->state->current_page--;
-
- /* Clear bits of page down. */
- ui->state->disabled_item_mask &= ~(1 << page_down_item);
-
if (ui->state->current_page == 0) {
- ui->state->disabled_item_mask |= 1 << page_up_item;
- ui->state->selected_item = page_down_item;
+ VB2_DEBUG("WARNING: Ignore page up on the first page\n");
+ ui->error_beep = 1;
+ return VB2_REQUEST_UI_CONTINUE;
}
+ ui->state->current_page--;
return VB2_REQUEST_UI_CONTINUE;
}
-static vb2_error_t log_page_next(struct vb2_ui_context *ui,
- uint32_t page_up_item,
- uint32_t page_down_item)
+static vb2_error_t log_page_next_action(struct vb2_ui_context *ui)
{
- if (ui->state->current_page == ui->state->page_count - 1)
- return VB2_REQUEST_UI_CONTINUE;
- ui->state->current_page++;
-
- /* Clear bits of page up. */
- ui->state->disabled_item_mask &= ~(1 << page_up_item);
-
if (ui->state->current_page == ui->state->page_count - 1) {
- ui->state->disabled_item_mask |= 1 << page_down_item;
- ui->state->selected_item = page_up_item;
+ VB2_DEBUG("WARNING: Ignore page down on the last page\n");
+ ui->error_beep = 1;
+ return VB2_REQUEST_UI_CONTINUE;
}
+ ui->state->current_page++;
return VB2_REQUEST_UI_CONTINUE;
}
@@ -258,7 +243,6 @@ static const struct vb2_screen_info advanced_options_screen = {
/******************************************************************************/
/* VB2_SCREEN_DEBUG_INFO */
-#define DEBUG_INFO_ITEM_PAGE_UP 1
#define DEBUG_INFO_ITEM_PAGE_DOWN 2
#define DEBUG_INFO_ITEM_BACK 3
@@ -278,7 +262,6 @@ static vb2_error_t debug_info_init(struct vb2_ui_context *ui)
}
return log_page_init(ui,
- DEBUG_INFO_ITEM_PAGE_UP,
DEBUG_INFO_ITEM_PAGE_DOWN,
DEBUG_INFO_ITEM_BACK);
}
@@ -301,29 +284,15 @@ static vb2_error_t debug_info_reinit(struct vb2_ui_context *ui)
return VB2_REQUEST_UI_CONTINUE;
}
-static vb2_error_t debug_info_page_prev_action(struct vb2_ui_context *ui)
-{
- return log_page_prev(ui,
- DEBUG_INFO_ITEM_PAGE_UP,
- DEBUG_INFO_ITEM_PAGE_DOWN);
-}
-
-static vb2_error_t debug_info_page_next_action(struct vb2_ui_context *ui)
-{
- return log_page_next(ui,
- DEBUG_INFO_ITEM_PAGE_UP,
- DEBUG_INFO_ITEM_PAGE_DOWN);
-}
-
static const struct vb2_menu_item debug_info_items[] = {
LANGUAGE_SELECT_ITEM,
- [DEBUG_INFO_ITEM_PAGE_UP] = {
+ {
.text = "Page up",
- .action = debug_info_page_prev_action,
+ .action = log_page_prev_action,
},
[DEBUG_INFO_ITEM_PAGE_DOWN] = {
.text = "Page down",
- .action = debug_info_page_next_action,
+ .action = log_page_next_action,
},
[DEBUG_INFO_ITEM_BACK] = BACK_ITEM,
POWER_OFF_ITEM,
@@ -340,7 +309,6 @@ static const struct vb2_screen_info debug_info_screen = {
/******************************************************************************/
/* VB2_SCREEN_FIRMWARE_LOG */
-#define FIRMWARE_LOG_ITEM_PAGE_UP 1
#define FIRMWARE_LOG_ITEM_PAGE_DOWN 2
#define FIRMWARE_LOG_ITEM_BACK 3
@@ -360,7 +328,6 @@ static vb2_error_t firmware_log_init(struct vb2_ui_context *ui)
}
return log_page_init(ui,
- FIRMWARE_LOG_ITEM_PAGE_UP,
FIRMWARE_LOG_ITEM_PAGE_DOWN,
FIRMWARE_LOG_ITEM_BACK);
}
@@ -383,29 +350,15 @@ static vb2_error_t firmware_log_reinit(struct vb2_ui_context *ui)
return VB2_REQUEST_UI_CONTINUE;
}
-static vb2_error_t firmware_log_page_prev_action(struct vb2_ui_context *ui)
-{
- return log_page_prev(ui,
- FIRMWARE_LOG_ITEM_PAGE_UP,
- FIRMWARE_LOG_ITEM_PAGE_DOWN);
-}
-
-static vb2_error_t firmware_log_page_next_action(struct vb2_ui_context *ui)
-{
- return log_page_next(ui,
- FIRMWARE_LOG_ITEM_PAGE_UP,
- FIRMWARE_LOG_ITEM_PAGE_DOWN);
-}
-
static const struct vb2_menu_item firmware_log_items[] = {
LANGUAGE_SELECT_ITEM,
- [FIRMWARE_LOG_ITEM_PAGE_UP] = {
+ {
.text = "Page up",
- .action = firmware_log_page_prev_action,
+ .action = log_page_prev_action,
},
[FIRMWARE_LOG_ITEM_PAGE_DOWN] = {
.text = "Page down",
- .action = firmware_log_page_next_action,
+ .action = log_page_next_action,
},
[FIRMWARE_LOG_ITEM_BACK] = BACK_ITEM,
POWER_OFF_ITEM,