From 203803bd9e9b9cac3049e10b68ff187f46bb0217 Mon Sep 17 00:00:00 2001 From: "7u83@mail.ru" <7u83@mail.ru@noemail.net> Date: Sun, 15 Mar 2015 11:36:43 +0000 Subject: [PATCH] Inital commit FossilOrigin-Name: ecb0d05ed50fcf56ce4278a1d8fcdae4bb112694ba72762b349f04a2bf66789d --- src/capwap/cw_readelem_ac_descriptor.c | 110 +++++++++++++++++++++++++ 1 file changed, 110 insertions(+) create mode 100644 src/capwap/cw_readelem_ac_descriptor.c diff --git a/src/capwap/cw_readelem_ac_descriptor.c b/src/capwap/cw_readelem_ac_descriptor.c new file mode 100644 index 00000000..d8b0e7b9 --- /dev/null +++ b/src/capwap/cw_readelem_ac_descriptor.c @@ -0,0 +1,110 @@ +#include + +#include "capwap.h" +#include "acinfo.h" +#include "bstr.h" + + + +static int read_subelem_cisco(struct ac_info* acinfo,int subtype,uint8_t * elem, int len) +{ + switch (subtype) { + case 0: + /* software version */ + bstr_replace(&acinfo->software_version,bstr_create(elem,len)); + break; + case 1: + /* hardware version */ + bstr_replace(&acinfo->hardware_version,bstr_create(elem,len)); + break; + + default: + printf("What? %d\n",subtype); + + } + + return 1; +} + + +static int read_subelem(struct ac_info* acinfo,int subtype,uint8_t *elem, int len) +{ + switch (subtype){ + case 4: + /* hardware version */ + bstr_replace(&acinfo->hardware_version,bstr_create(elem,len)); + break; + case 5: + /* software version */ + bstr_replace(&acinfo->software_version,bstr_create(elem,len)); + break; + } + + return 1; +} + + + +int cw_readelem_ac_descriptor(struct ac_info * acinfo,int type, uint8_t *msgelem, int len) +{ + if (type != CWMSGELEM_AC_DESCRIPTOR) + return 0; + + if (len<12) + return -1; + + uint32_t val; + + /* read stations and limit */ + val = ntohl(*((uint32_t*)msgelem)); + acinfo->stations = val>>16; + acinfo->limit = val&0xffff; + + + /* read active wtps and max wtps */ + val = ntohl(*((uint32_t*)(msgelem+4))); + acinfo->active_wtps = val>>16; + acinfo->max_wtps = val&0xffff; + + /* read active wtps and max wtps */ + val = ntohl(*((uint32_t*)(msgelem+8))); + acinfo->security = val >>24; + acinfo->rmac= (val >> 16)&0xff; + acinfo->dtls_policy=val&0xf; + + int sub=12; + int sublen; + + + while (sub>16; + + + switch (vendor) { + case 0: + read_subelem(acinfo,subtype,msgelem+sub,sublen); + break; + + case CW_VENDOR_ID_CISCO: + read_subelem_cisco(acinfo,subtype,msgelem+sub,sublen); + break; + + } + + if (sub+sublen>len) + return -1; + + sub+=sublen; + } + + return 1; +} + +