summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/stkutil.c28
-rw-r--r--src/stkutil.h6
2 files changed, 34 insertions, 0 deletions
diff --git a/src/stkutil.c b/src/stkutil.c
index 866b3223..e053e2cc 100644
--- a/src/stkutil.c
+++ b/src/stkutil.c
@@ -2685,6 +2685,31 @@ static gboolean parse_get_reader_status(struct stk_command *command,
return TRUE;
}
+static gboolean parse_timer_mgmt(struct stk_command *command,
+ struct comprehension_tlv_iter *iter)
+{
+ struct stk_command_timer_mgmt *obj = &command->timer_mgmt;
+ gboolean ret;
+
+ if (command->src != STK_DEVICE_IDENTITY_TYPE_UICC)
+ return FALSE;
+
+ if (command->dst != STK_DEVICE_IDENTITY_TYPE_TERMINAL)
+ return FALSE;
+
+ ret = parse_dataobj(iter, STK_DATA_OBJECT_TYPE_TIMER_ID,
+ DATAOBJ_FLAG_MANDATORY | DATAOBJ_FLAG_MINIMUM,
+ &obj->timer_id,
+ STK_DATA_OBJECT_TYPE_TIMER_VALUE, 0,
+ &obj->timer_value,
+ STK_DATA_OBJECT_TYPE_INVALID);
+
+ if (ret == FALSE)
+ return FALSE;
+
+ return TRUE;
+}
+
struct stk_command *stk_command_new_from_pdu(const unsigned char *pdu,
unsigned int len)
{
@@ -2797,6 +2822,9 @@ struct stk_command *stk_command_new_from_pdu(const unsigned char *pdu,
case STK_COMMAND_TYPE_GET_READER_STATUS:
ok = parse_get_reader_status(command, &iter);
break;
+ case STK_COMMAND_TYPE_TIMER_MANAGEMENT:
+ ok = parse_timer_mgmt(command, &iter);
+ break;
default:
ok = FALSE;
break;
diff --git a/src/stkutil.h b/src/stkutil.h
index 33d3ba8e..d18ada95 100644
--- a/src/stkutil.h
+++ b/src/stkutil.h
@@ -960,6 +960,11 @@ struct stk_command_perform_card_apdu {
struct stk_c_apdu c_apdu;
};
+struct stk_command_timer_mgmt {
+ unsigned char timer_id;
+ struct stk_timer_value timer_value;
+};
+
struct stk_command {
unsigned char number;
unsigned char type;
@@ -980,6 +985,7 @@ struct stk_command {
struct stk_command_refresh refresh;
struct stk_command_setup_event_list setup_event_list;
struct stk_command_perform_card_apdu perform_card_apdu;
+ struct stk_command_timer_mgmt timer_mgmt;
};
void (*destructor)(struct stk_command *command);