aboutsummaryrefslogtreecommitdiffstats
path: root/channels/iax2-parser.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-02-24 21:27:16 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-02-24 21:27:16 +0000
commit89db87c9d3523bcfd15441319322b6995a2bd02a (patch)
tree5ad5cad590bef104aa467e13d3758947336fec8c /channels/iax2-parser.c
parent90ee5c10094b0bcec991c1944dd2d142f9682e4f (diff)
Add IAX2 firmware upgrade support
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@2234 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels/iax2-parser.c')
-rwxr-xr-xchannels/iax2-parser.c38
1 files changed, 37 insertions, 1 deletions
diff --git a/channels/iax2-parser.c b/channels/iax2-parser.c
index 8ffbd2c69..32d40d129 100755
--- a/channels/iax2-parser.c
+++ b/channels/iax2-parser.c
@@ -120,6 +120,11 @@ static struct iax2_ie {
{ IAX_IE_PROVISIONING, "PROVISIONING" },
{ IAX_IE_AESPROVISIONING, "AES PROVISIONING" },
{ IAX_IE_DATETIME, "DATE TIME", dump_int },
+ { IAX_IE_DEVICETYPE, "DEVICE TYPE", dump_string },
+ { IAX_IE_SERVICEIDENT, "SERVICE IDENT", dump_string },
+ { IAX_IE_FIRMWAREVER, "FIRMWARE VER", dump_short },
+ { IAX_IE_FWBLOCKDESC, "FW BLOCK DESC", dump_int },
+ { IAX_IE_FWBLOCKDATA, "FW BLOCK DATA" },
};
const char *iax_ie2str(int ie)
@@ -158,7 +163,11 @@ static void dump_ies(unsigned char *iedata, int len)
snprintf(tmp, sizeof(tmp), " %-15.15s : %s\n", ies[x].name, interp);
outputf(tmp);
} else {
- snprintf(tmp, sizeof(tmp), " %-15.15s : Present\n", ies[x].name);
+ if (ielen)
+ snprintf(interp, sizeof(interp), "%d bytes", ielen);
+ else
+ strcpy(interp, "Present");
+ snprintf(tmp, sizeof(tmp), " %-15.15s : %s\n", ies[x].name, interp);
outputf(tmp);
}
found++;
@@ -223,6 +232,8 @@ void iax_showframe(struct iax_frame *f, struct ast_iax2_full_hdr *fhi, int rx, s
"UNSUPPORTED",
"TRANSFER",
"PROVISION",
+ "FWDOWNLD",
+ "FWDATA"
};
char *cmds[] = {
"(0?)",
@@ -363,6 +374,7 @@ int iax_parse_ies(struct iax_ies *ies, unsigned char *data, int datalen)
char tmp[256];
memset(ies, 0, sizeof(struct iax_ies));
ies->msgcount = -1;
+ ies->firmwarever = -1;
while(datalen >= 2) {
ie = data[0];
len = data[1];
@@ -507,6 +519,30 @@ int iax_parse_ies(struct iax_ies *ies, unsigned char *data, int datalen)
} else
ies->datetime = ntohl(*((unsigned int *)(data + 2)));
break;
+ case IAX_IE_FIRMWAREVER:
+ if (len != sizeof(unsigned short)) {
+ snprintf(tmp, sizeof(tmp), "Expecting firmwarever to be %d bytes long but was %d\n", sizeof(unsigned short), len);
+ errorf(tmp);
+ } else
+ ies->firmwarever = ntohs(*((unsigned short *)(data + 2)));
+ break;
+ case IAX_IE_DEVICETYPE:
+ ies->devicetype = data + 2;
+ break;
+ case IAX_IE_SERVICEIDENT:
+ ies->serviceident = data + 2;
+ break;
+ case IAX_IE_FWBLOCKDESC:
+ if (len != sizeof(unsigned int)) {
+ snprintf(tmp, sizeof(tmp), "Expected block desc to be %d bytes long but was %d\n", sizeof(unsigned int), len);
+ errorf(tmp);
+ } else
+ ies->fwdesc = ntohl(*((unsigned int *)(data + 2)));
+ break;
+ case IAX_IE_FWBLOCKDATA:
+ ies->fwdata = data + 2;
+ ies->fwdatalen = len;
+ break;
default:
snprintf(tmp, sizeof(tmp), "Ignoring unknown information element '%s' (%d) of length %d\n", iax_ie2str(ie), ie, len);
errorf(tmp);