summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/sccp.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/sccp.c b/src/sccp.c
index c14e850..cbc63b1 100644
--- a/src/sccp.c
+++ b/src/sccp.c
@@ -469,6 +469,18 @@ int _sccp_parse_udt(struct msgb *msgb, struct sccp_parse_result *result)
return _sccp_parse_unitdata(msgb, result, &offsets);
}
+int _sccp_parse_udts(struct msgb *msgb, struct sccp_parse_result *result)
+{
+ static const struct udt_offsets offsets = {
+ .header_size = sizeof(struct sccp_data_unitdata_service),
+ .called_offset = offsetof(struct sccp_data_unitdata_service, variable_called),
+ .calling_offset = offsetof(struct sccp_data_unitdata_service, variable_calling),
+ .data_offset = offsetof(struct sccp_data_unitdata_service, variable_data),
+ };
+
+ return _sccp_parse_unitdata(msgb, result, &offsets);
+}
+
static int _sccp_parse_xudt(struct msgb *msgb, struct sccp_parse_result *result)
{
static const struct udt_offsets offsets = {
@@ -481,6 +493,18 @@ static int _sccp_parse_xudt(struct msgb *msgb, struct sccp_parse_result *result)
return _sccp_parse_unitdata(msgb, result, &offsets);
}
+static int _sccp_parse_xudts(struct msgb *msgb, struct sccp_parse_result *result)
+{
+ static const struct udt_offsets offsets = {
+ .header_size = sizeof(struct sccp_data_ext_unitdata_service),
+ .called_offset = offsetof(struct sccp_data_ext_unitdata_service, variable_called),
+ .calling_offset = offsetof(struct sccp_data_ext_unitdata_service, variable_calling),
+ .data_offset = offsetof(struct sccp_data_ext_unitdata_service, variable_data),
+ };
+
+ return _sccp_parse_unitdata(msgb, result, &offsets);
+}
+
static int _sccp_parse_it(struct msgb *msgb, struct sccp_parse_result *result)
{
static const uint32_t header_size = sizeof(struct sccp_data_it);
@@ -1490,9 +1514,15 @@ int sccp_parse_header(struct msgb *msg, struct sccp_parse_result *result)
case SCCP_MSG_TYPE_UDT:
return _sccp_parse_udt(msg, result);
break;
+ case SCCP_MSG_TYPE_UDTS:
+ return _sccp_parse_udts(msg, result);
+ break;
case SCCP_MSG_TYPE_XUDT:
return _sccp_parse_xudt(msg, result);
break;
+ case SCCP_MSG_TYPE_XUDTS:
+ return _sccp_parse_xudts(msg, result);
+ break;
case SCCP_MSG_TYPE_IT:
return _sccp_parse_it(msg, result);
break;