aboutsummaryrefslogtreecommitdiff
path: root/libqcdm/src
diff options
context:
space:
mode:
Diffstat (limited to 'libqcdm/src')
-rw-r--r--libqcdm/src/commands.c49
-rw-r--r--libqcdm/src/commands.h18
-rw-r--r--libqcdm/src/dm-commands.h8
3 files changed, 75 insertions, 0 deletions
diff --git a/libqcdm/src/commands.c b/libqcdm/src/commands.c
index c0d0783b..9cc85e2e 100644
--- a/libqcdm/src/commands.c
+++ b/libqcdm/src/commands.c
@@ -287,6 +287,55 @@ qcdm_cmd_cdma_status_result (const char *buf, gsize len, GError **error)
/**********************************************************************/
gsize
+qcdm_cmd_sw_version_new (char *buf, gsize len, GError **error)
+{
+ char cmdbuf[3];
+ DMCmdHeader *cmd = (DMCmdHeader *) &cmdbuf[0];
+
+ g_return_val_if_fail (buf != NULL, 0);
+ g_return_val_if_fail (len >= sizeof (*cmd) + DIAG_TRAILER_LEN, 0);
+
+ memset (cmd, 0, sizeof (cmd));
+ cmd->code = DIAG_CMD_SW_VERSION;
+
+ return dm_encapsulate_buffer (cmdbuf, sizeof (*cmd), sizeof (cmdbuf), buf, len);
+}
+
+QCDMResult *
+qcdm_cmd_sw_version_result (const char *buf, gsize len, GError **error)
+{
+ QCDMResult *result = NULL;
+ DMCmdSwVersionRsp *rsp = (DMCmdSwVersionRsp *) buf;
+ char tmp[25];
+
+ g_return_val_if_fail (buf != NULL, NULL);
+
+ if (!check_command (buf, len, DIAG_CMD_SW_VERSION, sizeof (*rsp), error))
+ return NULL;
+
+ result = qcdm_result_new ();
+
+ memset (tmp, 0, sizeof (tmp));
+ g_assert (sizeof (rsp->version) <= sizeof (tmp));
+ memcpy (tmp, rsp->version, sizeof (rsp->version));
+ qcdm_result_add_string (result, QCDM_CMD_SW_VERSION_ITEM_VERSION, tmp);
+
+ memset (tmp, 0, sizeof (tmp));
+ g_assert (sizeof (rsp->comp_date) <= sizeof (tmp));
+ memcpy (tmp, rsp->comp_date, sizeof (rsp->comp_date));
+ qcdm_result_add_string (result, QCDM_CMD_SW_VERSION_ITEM_COMP_DATE, tmp);
+
+ memset (tmp, 0, sizeof (tmp));
+ g_assert (sizeof (rsp->comp_time) <= sizeof (tmp));
+ memcpy (tmp, rsp->comp_time, sizeof (rsp->comp_time));
+ qcdm_result_add_string (result, QCDM_CMD_SW_VERSION_ITEM_COMP_TIME, tmp);
+
+ return result;
+}
+
+/**********************************************************************/
+
+gsize
qcdm_cmd_nv_get_mdn_new (char *buf, gsize len, guint8 profile, GError **error)
{
char cmdbuf[sizeof (DMCmdNVReadWrite) + DIAG_TRAILER_LEN];
diff --git a/libqcdm/src/commands.h b/libqcdm/src/commands.h
index 4ca7909e..bc19334c 100644
--- a/libqcdm/src/commands.h
+++ b/libqcdm/src/commands.h
@@ -71,6 +71,24 @@ QCDMResult *qcdm_cmd_cdma_status_result (const char *buf,
/**********************************************************************/
+/* NOTE: this command does not appear to be implemented in recent
+ * devices and probably returns (QCDM_COMMAND_ERROR, QCDM_COMMAND_BAD_COMMAND).
+ */
+
+#define QCDM_CMD_SW_VERSION_ITEM_VERSION "version"
+#define QCDM_CMD_SW_VERSION_ITEM_COMP_DATE "comp-date"
+#define QCDM_CMD_SW_VERSION_ITEM_COMP_TIME "comp-time"
+
+gsize qcdm_cmd_sw_version_new (char *buf,
+ gsize len,
+ GError **error);
+
+QCDMResult *qcdm_cmd_sw_version_result (const char *buf,
+ gsize len,
+ GError **error);
+
+/**********************************************************************/
+
#define QCDM_CMD_NV_GET_MDN_ITEM_PROFILE "profile"
#define QCDM_CMD_NV_GET_MDN_ITEM_MDN "mdn"
diff --git a/libqcdm/src/dm-commands.h b/libqcdm/src/dm-commands.h
index 5bb05b35..f575b7ef 100644
--- a/libqcdm/src/dm-commands.h
+++ b/libqcdm/src/dm-commands.h
@@ -210,6 +210,14 @@ struct DMCmdStatusRsp {
} __attribute__ ((packed));
typedef struct DMCmdStatusRsp DMCmdStatusRsp;
+/* DIAG_CMD_SW_VERSION */
+struct DMCmdSwVersionRsp {
+ guint8 code;
+ char version[20];
+ char comp_date[11];
+ char comp_time[8];
+} __attribute__ ((packed));
+typedef struct DMCmdSwVersionRsp DMCmdSwVersionRsp;
#endif /* LIBQCDM_DM_COMMANDS_H */