LIAPP Frame Definition and Implementation

类别:软件工程 点击:0 评论:0 推荐:

 

 

 

 

 

 

 

 

 

 

 

LIAPP Frame Definition and Implementation

 

 

  

 

 

History

Date

Version

Author/ Revisor

Note

2004-7-31

1.0

Mitch

Add the SID and DID, and change version to 0xF600

2004-8-18

1.1

Mitch

Extent User Defined Request/Response to get the data that exceeds 1500 bytes

 

 

1.     Macro Definition

//-------------------------------------------------------------

//   common type definition for LIAPP

//-------------------------------------------------------------

#define U8     unsigned char               //1 byte

#define U16   unsigned short                     //2 bytes

#define U32   unsigned long                //4 bytes

 

#define IN

#define OUT

#define INOUT

2.     Frame Description 2.1.   Frame Structure

//-------------------------------------------------------------

//   Frame structure of protocol LIAPP
//-------------------------------------------------------------

 

Protocol ID

(0xF557)0xF600

 

2 bytes

Control

xx000000

1 byte

Destination

ID

 

4 bytes

Source

ID

 

4 bytes

Length

 

2 bytes

Sequence

 

2 bytes

Frame ID

 

2 bytes

Frame Body

 

N bytes

FCS

 

2 bytes

0 – 1

2

3 – 6

7 – 10

11 – 12

13 – 14

15 -- 16

 

 

Frame_Header

Frame_Body

 

 

2.2.   Frame Head Definition 2.2.1.    Frame Head structure

//----------------------------------------------------------------------------------------------------

//   Frame header structure of LIAPP, not include frame body and FCS.

//----------------------------------------------------------------------------------------------------

Typedef struct{

       U16        PID;

       U8          Ctrl;

U32        DID;

U32        SID;

       U16        Len;

       U16        Seq;

       U16        FID;

}LIAPP_HEADER;

 

//-------------------------------------------------------------

//   Macro definition for LIAPPheader

//-------------------------------------------------------------

#define LIAPP_MAXFRAMESIZE             1500                     //MAXSIZE for whole frame

#define LIAPP_PROTOCOLID                  (U16)0xF557        

#define LIAPP_PROTOCOLVERSION (U16)0                  //initial version is 0, not formal.

2.2.2.    Frame Id Field

//-------------------------------------------------------------

//   Definition of frame IDs of LIAPP frames

//-------------------------------------------------------------

#define LIAPP_FID_BROWSEREQ            0X0000

#define LIAPP_FID_BROWSERSP            0X0001

#define LIAPP_FID_INQUIRYREQ            0X0002

#define LIAPP_FID_INQUIRYRSP            0X0003

#define LIAPP_FID_CONNECTION          0X0004

#define LIAPP_FID_DISCONNECTION     0X0005

#define LIAPP_FID_CONFIGREQ             0X0006

#define LIAPP_FID_CONFIGRSP             0X0007

#define LIAPP_FID_FOPENREQ              0X0008

#define LIAPP_FID_FOPENRSP            0X0009

#define LIAPP_FID_FCLOSEREQ              0X000A

#define LIAPP_FID_FCLOSERSP           0X000B

#define LIAPP_FID_FREADREQ              0X000C

#define LIAPP_FID_FREADRSP                0X000D

#define LIAPP_FID_FWRITEREQ             0X000E

#define LIAPP_FID_FWRITERSP              0X000F

#define LIAPP_FID_DIRREQ                 0X0010

#define LIAPP_FID_DIRRSP               0X0011

#define LIAPP_FID_FSEEKREQ              0X0012

#define LIAPP_FID_FSEEKRSP            0X0013

#define LIAPP_FID_UDEFREQ             0X0014

#define LIAPP_FID_UDEFRSP              0X0015

//-------------------------------------------------------------

//    for testing the protocol

//-------------------------------------------------------------

#ifdef TESTCOMMQ

       #define LIAPP_FID_GETCQREQ        0x001a

       #define LIAPP_FID_GETCQRSP        0x001b

#endif

2.3.   Frame Body Description 2.3.1.    Precondition 2.3.1.1.            Status Code

//-------------------------------------------------------------

//   Definition of LIAPP_STATUS

//-------------------------------------------------------------

typedef int LIAPP_STATUS;

enum _LIAPP_STATUS {

LIAPP_STATUS_SUCCESS,                                    //0

       LIAPP_STATUS_FAILURE,                                     //1

     LIAPP_STATUS_TIMEOUT,                             //2

      LIAPP_STATUS_BUSY,                                    //3

       LIAPP_STATUS_INVALID_USER,                           //4

       LIAPP_STATUS_REJECT,                                       //5

       LIAPP_STATUS_DISCONNECTION,                       //6

      LIAPP_STATUS_INVALID,                                     //7

      LIAPP_STATUS_OVERFLOW,                                //8

    LIAPP_STATUS_NOTFOUND                                 //9

};

2.3.1.2.            Prompt & Error Messages

//-------------------------------------------------------------

//     In the Lib.h

//    Prompt & Error Messages

//-------------------------------------------------------------

Note: if you want to know the lastest macros of PEMs, please refer your question to the Lib.h of Nobrand Smart Utility for all models

 

#define Meg                 "Message..."

#define Meg_Nu              "You must input a password!"

#define Meg_xpas            "Invalid password!"

#define Meg_cpas            "The new configuration has applied successfully.\n" \

                            " Reset AP in process..."

#define Meg_cxpas           "Fail to apply new configuration!"

#define Meg_rpas            "Reset AP in process..."

#define Meg_rxpas           "Fail to reset!"

#define Meg_upas            "The firmware has upgraded sucessfully.\n" \

                            " Reset AP in process..."

#define Meg_uxpas           "Fail to upgrade!"

#define Meg_dump            "AP Name"

#define Meg_outrts          "RTS threshold is out of range!"

#define Meg_outfrag         "Frag threshold is out of range!"

#define Meg_difpas          "Password mismatch!"

#define Meg_openfail        "Fail to open the file!"

#define Meg_overflow        "File size overflow!"

#define Meg_Noimport        "Invalid import file!"

#define Meg_outimport       "Import file too large!"

#define Meg_accessapy       "The new configuration has applied successfully.\n" \

                            " Reset AP in process..."

#define Meg_accessapy2      "The new configuration has applied successfully.\n"

#define Meg_xaccessapy      "Fail to apply!"

#define Meg_xaccess         "Invalid MAC address!"

#define Meg_xdaccess        "Duplicate address!"

#define Meg_dcheck          "The AP will be reset. Are you sure to proceed??"

#define Meg_dcheck2         "Are you sure to update Access Control Table??"

#define Meg_xip             "Invaild IP address."

#define Meg_xgateway        "Invalid Gateway address."

#define Meg_xnetmask        "Invalid Netmask address."

 

#define Meg_Wep1            "Key %d : Invalid key format."

#define Meg_Wep2            "Key %d : Key size should be %d bytes."

 

#define Meg_string1         "Browse Result"

#define Meg_string2         "Inquiry Result"

#define Meg_string3         "Connect Result"

#define Meg_string4         "Disconnect Result"

#define Meg_string5         "Configuration Result"

#define Meg_string6         "Open File Result"

#define Meg_string7         "Close File Result"

#define Meg_string8         "Read File Result"

#define Meg_string9         "Write File Result"

#define Meg_string10        "List File Result"

#define Meg_string11        "Seek File Result"

 

#define Meg_result1         "Success!"

#define Meg_result2         "Failure!"

#define Meg_result3         "Timeout!"

#define Meg_result4         "Busy!"

#define Meg_result5         "Invalid User!"

#define Meg_result6         "Reject!"

#define Meg_result7         "Disconnection!"

//#define Meg_result8         "Invalid request parameter"

#define Meg_result8         "Settings cannot be changed with this version of utility"

#define Meg_result9         "Overflow"

#define Meg_result10        "Not found "

2.3.1.3.            Device Id

//-------------------------------------------------------------

//      Definition of device Id information

//-------------------------------------------------------------

Note:In the LIAPP, length =6;and ID[0..5]=BSSID

typedef struct{

       char length;

       char ID[16];                 //last char implies network interface    

} DEVID;

2.3.1.4.            Device Description

//-------------------------------------------------------------

//      Definition of format of device description

//-------------------------------------------------------------

Note: Need modification for the XG582

typedef struct{

        DEVID deviceId;

        char manufacturer[80];

        char product[80];

        char model[80];

        char name[80];                           //Device(AP) name

        char detail[256];                          //Device(AP) description

} DEVDESC;

2.3.1.5.            Element Format

Note:In the Utility and Firmware, we don’t accord with following Element Class

Element ID

Element Length

Element Value

2 bytes

1 byte

N bytes

 

Element Class

Element Number

Bit 15 – bit 12

Bit 11 – bit 0

Element ID field description

Element Class

Description

0

General Information

1

Wireless LAN1 Information

Element class description

//---------------------------------------------------------------------------------------------

typedef  U16  EID;                                        // EID is nothing but a shot

//---------------------------------------------------------------------------------------------

typedef struct{

       EID        eid;

       U8         len;

       U8         value[255];

} ELEMENT;

#define EID_End    (U16)0xFFFF                     //impossible EID for normal element

2.3.1.6.            AP Configuration Definition

Note: Do not use in the Utility.

//---------------------------------------------------------------------------

//     Appear in the file Apcfg.h

//---------------------------------------------------------------------------

typedef struct _AP_CONFIG

{

       u_char                  wla_if_no;

       APCFG_WlaIf              wla_ifp[MAX_NO_WIFACE];

#ifndef MAP

       APCFG_IP            ip;

#ifdef STATIC_ROUTE

       APCFG_ROUTE           route;

#endif    

       APCFG_DHCPD           dhcpd;

       APCFG_SNMP             snmp;

       APCFG_Mgmt              mgmt;

       APCFG_Various            var;

       APCFG_AccessCtrl       access;

       APCFG_PPPoE             pppoe;

 

//UserAuth Related

       APCFG_RadiusCtrl radius;

//UserAuth Related end

       APCFG_ThroughputCtl  throughputctl;

#endif

} AP_CONFIG;

2.3.1.7.            Mib Structure

Note: See XI1500, not in XG580SERIES

//---------------------------------------------------------------------------

//     Appear in the file Mib.h

//---------------------------------------------------------------------------

//    Define MIB attribute for MIBATT

//    Amdin user ignore MIBATT, can full access

//---------------------------------------------------------------------------

#define EATT_NA 0     //not used

#define EATT_RO 1     //read only

#define EATT_WO 2     //write only

#define EATT_RW 3     //full access

//---------------------------------------------------------------------------

//    Define general MIB

//   f(ENAME,EATT,EMAX,ELEN,EVALUE)

//   Note 1: you cannot delete any EID from here,

//   because the EID is unique for each element

//   for a unused EID, please set EATT=EATT_NA

//   Note 2: total items < 0x1000, EID=0x0000-0x0FFF

//---------------------------------------------------------------------------

#define defGenMIB(f) \

f(MIBVersion_Major,EATT_RO,1,1,unsigned char,{1})\

f(MIBVersion_Middle,EATT_RO,1,1,unsigned char,{0})\

f(MIBVersion_Minor,EATT_RO,1,1,unsigned char,{0})\

f(FWVersion_Major,EATT_RO,1,1,unsigned char,{1})\

f(FWVersion_Middle,EATT_RO,1,1,unsigned char,{0})\

f(FWVersion_Minor,EATT_RO,1,1,unsigned char,{0})\

f(FW_Build_Date,EATT_RO,32,1,char,{0})\

f(FW_Upload_Date,EATT_RO,32,1,char,{0})\

f(Manufacturer,EATT_RO,sizeof("Z-Com"),sizeof("Z-Com")-1,char,"Z-Com")\

        f(Product,EATT_RO,sizeof("LANEscape"),sizeof("LANEscape")-1,char,"LANEscape")\

f(Model,EATT_RO,sizeof("XI-1000"),sizeof("XI-1000")-1,char,"XI-1000")\

f(Name,EATT_RW,16,sizeof("AP0001")-1,char,"AP0001")\

f(Detail,EATT_RW,80,0,char,"")\

f(Username,EATT_RO,sizeof("guest"),sizeof("guest")-1,char,"guest")\

f(Password,EATT_RW,16,sizeof("1234")-1,char,"1234")

 

 

//---------------------------------------------------------------------------

//      define 802.11 MIB (Wireless LAN 1)

//      f(ENAME,EATT,EMAX,ELEN,EVALUE)

//      Note 1: you cannot delete any EID from here,

//              because the EID is unique for each element

//              for a unused EID, please set EATT=EATT_NA

//      Note 2: total items < 0x1000,  EID=0x1000-0x1FFF

//---------------------------------------------------------------------------

#define dChannelList {1,2,3,4,5,6,7,8,9,10,11,12,13,14,0}

#define dSupportRate {2,4,11,22,0}

#define defWla1MIB(f) \

f(WLA1_MacAddr,EATT_RO,6,6,char,"")\

f(WLA1_FreqDomain,EATT_RO,1,1,char,{FD_FCC})\

f(WLA1_ChannelList,EATT_RO,15,15,char,dChannelList)\

f(WLA1_ChannelNumber,EATT_RW,1,1,char,{1})\

f(WLA1_SupportRates,EATT_RO,5,5,char,dSupportRate)\

f(WLA1_BasicRates,EATT_RW,5,5,char,"\4")\

f(WLA1_TxRate,EATT_RW,1,1,char,{TXRATE_FullAuto})\

f(WLA1_ESSID,EATT_RW,30,30,char,"My Network")\

f(WLA1_RTSThreshold,EATT_RW,1,1,short,{2300})\

/*

f(WLA1_TransmittedFragmentCount,EATT_RO,1,1,long,{0})\

f(WLA1_MulticastTransmittedFrameCount,EATT_RO,1,1,long,{0})\

f(WLA1_RetryCount,EATT_RO,1,1,long,{0})\

f(WLA1_FailedCount,EATT_RO,1,1,long,{0})\

f(WLA1_MultipleRetryCount,EATT_RO,1,1,long,{0})\

f(WLA1_FrameDuplicateCount,EATT_RO,1,1,long,{0})\

f(WLA1_RTSSuccessCount,EATT_RO,1,1,long,{0})\

f(WLA1_RTSFailureCount,EATT_RO,1,1,long,{0})\

f(WLA1_ACKFailureCount,EATT_RO,1,1,long,{0})\

f(WLA1_ReceiveFragmentCount,EATT_RO,1,1,long,{0})\

f(WLA1_MulticastReceivedCount,EATT_RO,1,1,long,{0})\

f(WLA1_FCSErrorCount,EATT_RO,1,1,long,{0})

*/

 

//---------------------------------------------------------------------------

//      define element Ids

//---------------------------------------------------------------------------

#define f_enum(ENAME,EATT,EMAX,ELEN,ETYPE,EVALUE) EID_##ENAME,

enum _EID_GEN_{

    genfirsteid=0x0000-1,

    defGenMIB(f_enum)

    genlasteid

};

enum _EID_WLA1_{

    wla1firsteid=0x1000-1,

    defWla1MIB(f_enum)

    wla1lasteid

};

 

//---------------------------------------------------------------------------

//      define attributes of MIBs

//---------------------------------------------------------------------------

#define f_ATT(ENAME,EATT,EMAX,ELEN,ETYPE,EVALUE) EATT,

unsigned char MIB_GenAttr[TOTAL_GEN]={defGenMIB(f_ATT)};

unsigned char MIB_Wla1Attr[TOTAL_WLA1]={defWla1MIB(f_ATT)};

//---------------------------------------------------------------------------

//      define elements's max length

//---------------------------------------------------------------------------

#define f_maxlen(ENAME,EATT,EMAX,ELEN,ETYPE,EVALUE)\

        EMAX*sizeof(ETYPE),

unsigned char MIB_GenMaxLen[TOTAL_GEN]={defGenMIB(f_maxlen)};

unsigned char MIB_Wla1MaxLen[TOTAL_WLA1]={defWla1MIB(f_maxlen)};

//---------------------------------------------------------------------------

//      define elements's length

//---------------------------------------------------------------------------

#define f_len(ENAME,EATT,EMAX,ELEN,ETYPE,EVALUE)\

        ELEN*sizeof(ETYPE),

unsigned char MIB_GenLen[TOTAL_GEN]={defGenMIB(f_len)};

unsigned char MIB_Wla1Len[TOTAL_WLA1]={defWla1MIB(f_len)};

//---------------------------------------------------------------------------

//      define values of MIBs

//---------------------------------------------------------------------------

#define f_values(ENAME,EATT,EMAX,ELEN,ETYPE,EVALUE)\

        static ETYPE EVA_##ENAME[EMAX]=EVALUE;

defGenMIB(f_values)

defWla1MIB(f_values)

//---------------------------------------------------------------------------

//      define element map

//---------------------------------------------------------------------------

#define f_map(ENAME,EATT,EMAX,ELEN,ETYPE,EVALUE)\

        (void*)EVA_##ENAME,

 

void * MIB_GenMap[TOTAL_GEN]={defGenMIB(f_map)};

void * MIB_Wla1Map[TOTAL_WLA1]={defWla1MIB(f_map)};

2.3.2.    Frame Format Definition

Note: The following frame formats are based on <LANEscape Inter Access Point Protocol (LIAPP) Specification v0.3 Draft> , Released by Sean Huang, and maybe not be same with the implement of the protocol. The main reason, I adhere to implement the structure of these frame formats, is that people can easy to communicate with each other, according as the frame formats defined by the protocol.

2.3.2.1.            Browse Request Frame Format

Typedef struct{

ELEMENT BROWSE_ manufacturer;                 //len=0

ELEMENT BROWSE_ product;                         //len=0

ELEMENT BROWSE_ model;                           //len=0

}LIAPP_FB_BROWSEREQ;

2.3.2.2.            Browse Response Frame Format

Note: Need modification for XG582

Typedef struct{

ELEMENT BROWSE_ manufacturer;

ELEMENT BROWSE_ product;

ELEMENT BROWSE_ model;

ELEMENT BROWSE_ apname;

ELEMENT BROWSE_ detail;

}LIAPP_FB_BROWSERSP;

2.3.2.3.            Inquiry Request Frame Format

Typedef struct{

       U16 INQ_userId;                        //user ID

       DEVID INQ_deviceId;                 //device Id

}LIAPP_FB_INQREQ;

2.3.2.4.            Inquiry Response Frame Format

Typedef struct{

       U16 INQ_userId;                        //user ID

       U16 INQ_state;                           //status code

       DEVID INQ_deviceId;                 //device Id

}LIAPP_FB_INQRSP;

2.3.2.5.            Configuration Request Frame Format

Typedef struct{

       U16 CONF_userId;                            //user ID

       DEVID CONF_deviceId;              //device Id

}LIAPP_FB_CONFREQ;

2.3.2.6.            Configuration Response Frame Format

Typedef struct{

U16 CONF_userId;                            //user ID

U16 CONF_state;                        //status code

}LIAPP_FB_CONFRSP;

2.3.2.7.            Connection Frame Format

Typedef struct{

       U16 CONN_seq;                         //connection transaction sequence number

       U16 CONN_state;                       //status code

       U16 CONN_userId;                     //user ID

       U8 *CONN_name[20];                //user name

       U8 *CONN_password[20];          //password

}LIAPP_FB_CONNECTION;

//------------------------------------------------------------------------------------------

//     In the Implement of the LIAPP, Red Field (User Name) is omiited.

//------------------------------------------------------------------------------------------

Connection transaction sequence number

Status code

User Id

User name

Password

1

Reserved 0

Reserved 0

Present

Present

2

Status

Present

Not present

Not present

3

Reserved 0

Present

Present

Not present

4

Status

Present

Not present

Not present

2.3.2.8.            Disconnection Frame Format

Typedef struct{

       U16 DISC_userId;                //user ID

}LIAPP_FB_DISCONNECTION;

2.3.2.9.            File Open Request Frame Format

Typedef struct{

       U16 FOPEN_userId;                           //user ID

       U16 FOPEN_attr                                //attribute r/w

       U8   FOPEN_filename[20]                   //file name, max 16

}LIAPP_FB_FOPENREQ;

2.3.2.10.       File Open Response Frame Format

Typedef struct{

       U16 FOPEN_userId;                           //user ID

       U16 FOPEN_state                              //status code

       U16 FOPEN_fileId;                            //file ID

       U32 FOPEN_size                               //file size

}LIAPP_FB_FOPENRSP

2.3.2.11.       File Close Request Frame Format

Typedef struct{

       U16 FCLOSE_userId;                         //user ID

       U16 FCLOSE_fileId;                          //file ID

}LIAPP_FB_FCLOSEREQ;

2.3.2.12.       File Close Response Frame Format

Typedef struct{

       U16 FCLOSE_userId;                         //user ID

       U16 FCLOSE_fileId;                          //file ID

       U16 FCLOSE_state;                           //status code

}LIAPP_FB_FCLOSERSP;

 

2.3.2.13.       File Write Request Frame Format

Typedef struct{

       U16 FWRITE_userId;                         //user ID

       U16 FWRITE_fileId;                          //file ID

       U16 FWRITE_bytes2Write;                 // bytes to write, only 2 bytes

       U32 FWRITE_byteOffset;                   //byte offset

       U8* FWRITE_data2Write;                  //data to write

}LIAPP_FB_FWRITEREQ;

2.3.2.14.       File Write Response Frame Format

Typedef struct{

       U16 FWRITE_userId;                         //user ID

       U16 FWRITE_fileId;                          //file ID

       U16 FWRITE_state;                           //status code

       U16 FWRITE_bytes2Write;                 // bytes to write, only 2 bytes

       U32 FWRITE_byteOffset;                   //byte offset

}LIAPP_FB_FWRITERSP;

2.3.2.15.       File Read Request Frame Format

Typedef struct{

       U16 FREAD_userId;                           //user ID

       U16 FREAD_fileId;                            //file ID

       U16 FREAD_bytes2Read;                   // bytes to read

       U32 FREAD_byteOffset;                     //byte offset

}LIAPP_FB_FREADREQ;

2.3.2.16.       File Read Response Frame Format

Typedef struct{

       U16 FREAD_userId;                           //user ID

       U16 FREAD_fileId;                            //file ID

       U16 FREAD_state;                             //status code

       U16 FREAD_bytes2Read;                   // bytes to read

       U32 FREAD_byteOffset;                     //byte offset

       U8* FREAD_data2Read;                     //data to read

}LIAPP_FB_FREADRSP;

2.3.2.17.       User Defined Request Frame Format

Typedef struct{

       U16 UDEF_userId;                      //user ID

       U16 UDEF_len;                           //body length

       U8* UDEF_buff;                         //body

}LIAPP_FB_UDEFREQ;

2.3.2.18.       User Defined Response Frame Format

Typedef struct{

       U16 UDEF_userId;                      //user ID

       U16 UDEF_state;                        //status code

       U16 UDEF_len                            //return length

       U8* UDEF_buff;                         //return buffer

}LIAPP_FB_UDEFRSP;

 

Below frame format is not defined and implemented in the LIAPP.

2.3.2.19.       DIR Request Frame Format 2.3.2.20.       DIR Response Frame Format 2.3.2.21.       File Seek Request Frame Format 2.3.2.22.       File Seek Response Frame Format 3.     Variables and Routines 3.1.   Definition 3.1.1.    LIAPP Status

//-------------------------------------------------------------

//   Definition of LIAPP_STATE

//-------------------------------------------------------------

typedef int LIAPP_STATE;

enum _LIAPP_STATE{LIAPP_STATE_NOCONNECTION,LIAPP_STATE_CONNECTION};

enum _CONNECT_STATE{CONN_IDLE,CONN_WAIT_SEQ2,CONN_WAIT_SEQ4};

enum _BROWSE_STATE{BROWSE_IDLE,BROWSE_WAIT_RSP};

enum _INQ_STATE{INQ_IDLE,INQ_WAIT_RSP};

enum _CONF_STATE{CONF_IDLE,CONF_WAIT_RSP};

enum _FOPEN_STATE{FOPEN_IDLE,FOPEN_WAIT_RSP};

enum _FCLOSE_STATE{FCLOSE_IDLE,FCLOSE_WAIT_RSP};

enum _FWRITE_STATE{FWRITE_IDLE,FWRITE_WAIT_RSP};

enum _FREAD_STATE{FREAD_IDLE,FREAD_WAIT_RSP};

enum _UDEF_STATE{UDEF_IDLE,UDEF_WAIT_RSP};

#ifdef TESTCOMMQ

enum _CQREQ_STATE{CQREQ_IDLE,CQREQ_WAIT_RSP};

#endif

3.1.2.    LIAPP Station

//-------------------------------------------------------------

//   Definition of LIAPP_STATION

//-------------------------------------------------------------

Typedef  U16 LIAPP_STATION;

enum _LIAPP_STATION{

       LIAPP_STATION_CLIENT,

       LIAPP_STATION_SERVER

};

3.1.3.    LIAPP Device Node

//-------------------------------------------------------------

//     Definition of LIAPP_DEVNODE

//-------------------------------------------------------------

Note: This structure is used in Firmware to manage the UID.

typedef struct {

U8                       inuse;                    //y/n

DEVID                 deviceId;

LIAPP_STATE      state;

    U8                       admin;                  //used in server mode only, validate user

} DEVNODE;

3.2.   Variables 3.2.1.    LIAPP General Variables

#define  ACCESS_LIMIT   1000

#define  MAXDEVICE       250         //32

#define  MAXBROWSE      250         //100

 

#define MAXNODES 8                       //maxsize of users for one device

#define LANEscapeType      0xAAAA

3.2.2.    LIAPP Variables provided by the LIAPP

//------------------------------------------------------------------------------

//     The below varibles are defined in the document of the LIAPP,

//     but some are not implemented in the Liapp.c

//------------------------------------------------------------------------------

Char LIAPP_MyDeviceId[16]; //not defined

Char LIAPP_State; //changed

Char LIAPP_Prestate; //changed

Char LIAPP_RetryLimit;

Char LIAPP_username; //not defined

Char LIAPP_DeviceIdofConnection; //not defined

 

//------------------------------------------------------------------------------

//     The below varibles are found in the Liapp.c

//------------------------------------------------------------------------------

LIAPP_STATE LIAPP_state;

LIAPP_STATE LIAPP_prestate;

 

U8               LIAPP_mysequence;

U16      LIAPP_maxframesize=1500;

U8               LIAPP_retrylimit=0;

U16      LIAPP_timeout=100;

3.2.3.    LIAPP Variables provided by Utility Interface

MACRO LIAPP_WaitEvent(Event, timeout) //not defined

Event LIAPP_InquiryCompleteEvent //not defined

Event LIAPP_ConfigurationCompleteEvent //not defined

Event LIAPP_StartUploadCompleteEvent //not defined

Event LIAPP_StartDownloadCompleteEvent //not defined

Event LIAPP_UploadCompleteEvent //not defined

Event LIAPP_DownloadCompleteEvent //not defined

Event LIAPP_EndUploadCompleteEvent //not defined

Event LIAPP_EndDownloadCompleteEvent //not defined

 

3.3.   Routines 3.3.1.    Support Routines Provided by the LIAPP

//------------------------------------------------------------------------------

//     Utility calls routines defined in the document of  the LIAPP,

//     but some routines are not been implemented in the Liapp.c

//------------------------------------------------------------------------------

STATUS LIAPP_Initialize(char *DeviceId, );

STATUS LIAPP_Indication(char *DeviceId, char *Frame, int Length);

STATUS LIAPP_Browse(char *Manufacturer, char *Product, char *Model, int timeout);

STATUS LIAPP_Inquiry(char *ElementIdList, int timeout);

STATUS LIAPP_Configuration(char *ElementList, int timeout);

//Programmer says that utility calls LIAPP_Config to update information in the Liapp.c, but LIAPP_Update is defined to complete the same function instead of LIAPP_Config.

STATUS LIAPP_StartUpload(void);//not defined

STATUS LIAPP_Upload(char Buffer2Upload, long Bytes2Upload, long timeout);//not defined

STATUS LIAPP_SendEndUpload(void);//not defined

STATUS LIAPP_StartDownload(void);//not defined

STATUS LIAPP_Download(char Buffer2Download, long Bytes2Download, short timeout);//not defined

STATUS LIAPP_SendEndDownload(void);//not defined

STATUS LIAPP_Action(int ActionId, short timeout);//not defined

 

//---------------------------------------------------------------------------------

//     Supporting Inter Routines provided by the LIAPP in the Frams.h

//---------------------------------------------------------------------------------

int mkframe(char *frame,short FrameId,int Sequence,...);

int ValidLIAPPframe(char *frame, int len, LIAPP_HEADER *);

void LIAPP_IndFrames(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

 

//---------------------------------------------------------------------------------

//     Supporting Inter Routines provided by the LIAPP in the Frams.c

//---------------------------------------------------------------------------------

//     General Routines for all others

//---------------------------------------------------------------------------------

static void Ind_Connection(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_Disconnection(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

 

#ifdef _LIAPP_CLIENT_

//--------------------------------------------------------------------------------

//     Support as a utility which gets and deals with responses

//--------------------------------------------------------------------------------

static void Ind_FopenRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_ConfigRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_InquiryRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_FcloseRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_BrowseRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_FreadRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_FwriteRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_UDEFRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

#ifdef TESTCOMMQ

static void Ind_GetCQRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

#endif

#else

//-----------------------------------------------------------------------------------

//     Support as a server which gets and deals with requests.

//-----------------------------------------------------------------------------------

static void Ind_BrowseReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_InquiryReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_ConfigReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_FopenReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_FcloseReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_FwriteReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_FreadReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_UDEFReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

#ifdef TESTCOMMQ

static void Ind_GetCQReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

#endif  

#endif

 

//---------------------------------------------------------------------------------

//     Supporting Inter Routines provided by the LIAPP in the LIAPP.h and the LIAPP.c

//---------------------------------------------------------------------------------

char *findeid(char *body,int bodylen,EID eid);

int findelement(char *body,int bodylen,EID eid,char *buf,int buflen);

LIAPP_STATE UserState(unsigned short userId, DEVID *deviceId);

unsigned short AddUser(DEVID *,LIAPP_STATE,unsigned char);

int DelUser(unsigned short userId);

int IsAdmin(unsigned short userId);

unsigned short nextConnection(void);

int ExistConnection(unsigned short userId);

 

//-------------------------------------------------------------------------------------

//   Utility can call following routines provided by the LIAPP in the Liapp.h

//--------------------------------------------------------------------------------------

void LIAPP_ConnectionTimer(void);

LIAPP_STATUS LIAPP_Initialize(int,int,int);

LIAPP_STATUS LIAPP_SetTimeout(int timeout);

int LIAPP_GetTimeout(void);

LIAPP_STATUS LIAPP_Indication(DEVID *,char*,int);

LIAPP_STATUS LIAPP_Browse(ELEMENT*,ELEMENT*,ELEMENT*r,DEVDESC*,int*);

LIAPP_STATUS LIAPP_BrowseMany(int ModelCount,ELEMENT *manu[],ELEMENT *prod[],ELEMENT *model[],DEVDESC*,int*);

LIAPP_STATUS LIAPP_Inquiry(unsigned short,EID*,char*,int);

LIAPP_STATUS LIAPP_Update(unsigned short,ELEMENT*,int);

LIAPP_STATUS LIAPP_Connect(DEVID*,char*,char*,unsigned short*);

LIAPP_STATUS LIAPP_Disconnect(unsigned short);

LIAPP_STATUS LIAPP_Fopen(unsigned short,char*,unsigned char,short*,unsigned long*);

LIAPP_STATUS LIAPP_Fwrite(unsigned short userId,unsigned short fileId,unsigned long byteoffset,char *buf,unsigned long buflen);

LIAPP_STATUS LIAPP_Fread(unsigned short userId,unsigned short fileId,unsigned long byteoffset,char *buf,unsigned long *buflen);

LIAPP_STATUS LIAPP_Fclose(unsigned short userId,unsigned short fileId);

LIAPP_STATUS LIAPP_UserDefine(unsigned short userId,char *buf,int buflen,char** retbuf,int *retlen);

#ifdef TESTCOMMQ

LIAPP_STATUS LIAPP_GetCQReq(unsigned short userId,char *buf,int buflen);

#endif

3.3.2.    Support Routines provided by Utility Interface

//------------------------------------------------------------------------------------------------------

//     Utility calls routines as Utility Interfaces defined in the document of the LIAPP

//------------------------------------------------------------------------------------------------------

TIMERID SetTimer(void * TimeoutCall, int timeout);//not defined

BOOLEAN StopTimer(TIMERID TimerId);//not defined

BOOLEAN LIAPP_Validuser(char *username, char *password);//not defined

BOOLEAN LIAPP_Send(char *DeviceId, char *Frame, int length);//not defined

BOOLEAN LIAPP_Write(char *username, char *destination, char *source, int length);//not defined

BOOLEAN LIAPP_Read(char *username, char *destination, char *source, int length);//not defined

BOOLEAN LIAPP_SetElement(int ElementId, int ElementLength, char *ElementValue);//not defined

BOOLAEN LIAPP_GetElement(int ElementId, int MaxElementLength, char *ElementValue);//not defined

Void LIAPP_NotifyEndUpload(void);//not defined

Void LIAPP_NotifyEndDownload(void);//not defined

3.3.3.    Routines Call Relationship

//------------------------------------------------------------------------------------------------------

//     Routines call relationship from top to down

//------------------------------------------------------------------------------------------------------

l       Application calls protocol                    //APIs are to be enriched

APIs supported by LIAPP: LIAPP_*

l       Protocol calls UIF and MIB                      //steady

UIF is relative to network: UIF_*()

MIB is relative to configuration: QueryMIB() and UpdateMIB()

l       UIF calls adapter                                       //steady

Uif_Send() Sends:         Write_Packet()

ReceivePkt() Receives:   Read_Packet()

l       Adapter calls Windis                                 //steady

Write_Packet():    W32N_PacketSend()

Read_Packet():    W32N_PacketRead()

4.     Implementation Notes 4.1.   Make Frame

//------------------------------------------------------------------------------------------------------

//     Pay attention to the variables of frame and dest

//------------------------------------------------------------------------------------------------------

int mkframe(   char *frame,                 //the address of the whole frame of the LIAPP

short Sequence,

int FrameId,

...

);

static int cpyshort( char *frame,          //the address of the whole frame of the LIAPP

char *dest,            //the other field of LIAPP, usually use offset plus frame

short value

)

 

static int mkchar(char *frame,char **dest,char value); // the same

static int mkshort(char *frame,char **dest,short value);

static int mklong(char *frame,char **dest,long value);

static int mkstr(char *frame,char **dest,char* str);

static int cpychar(char *frame,char *dest,char value);

static int cpyshort(char *frame,char *dest,short value);

 

//------------------------------------------------------------------------------------------------------

//     Following variables of va_* given in the Apdialog.h are very important that

//     all the frame bodys are directed by va_list, and frame body fields are gotten by

//     function va_arg().

//------------------------------------------------------------------------------------------------------

va_list ap;                                          //ap is the array point;

va_start(ap,FrameId);                        //ap points to the address of the frame body

va_arg(ap,ELEMENT *)                            //it’s a key,

va_end(ap);                                       // ap points to (char *)-256)

 

//------------------------------------------------------------------------------------------------------

//     In thr frame of CONNECTION, User Name and Password is packed as elements.

//     Why? I think that maybe the length of Name and Password is not measured., so

//     programer do it as elements.

//     Why not use function mkelement()? Because User Name is not an elemnet type.

//------------------------------------------------------------------------------------------------------

mkelement2(frame,&p,EID_adm_name,strlen(user),user))

mkelement2(frame,&p,EID_adm_passwd,strlen(pwd),pwd))

 

//-----------------------------------------------------------------------------------------------------

//     Line1418 in the Frames.c.

//     in the code, I can not find the operation with FCS, but when counting the length

//     of the frame, we should plus 2. otherwhere we should do the same.

//------------------------------------------------------------------------------------------------------

if (((int)(p-frame)+len+2) > LIAPP_maxframesize) return 0; //2 is the length of FCS

 

//-----------------------------------------------------------------------------------------------------

//     From line1498 to line 1502 in the Frames.c.

//     We find that variable length dose not include the length of FCS, but it does not suit

//     for the LIAPP.

//------------------------------------------------------------------------------------------------------

Note: The length of variables is not right now. For detail, see LIAPP

length = (int)(p-frame-5);

cpyshort(frame,(char*)frame+3, length);

FCS = Crc16((unsigned char*)frame+5, length, 0);

cpyshort(frame,(char*)(frame+length+5),FCS);

return (length+5+2);                                         //return frame size, 0 for failure

4.2.   Indicate Connection

//-----------------------------------------------------------------------------------------------------

//     Line 954 in the Frames.c

//     Why does connnseq have 4 statuses?

//     CONN_WAIT_SEQ2 and CONN_WAIT_SEQ4?

//     I think that server and utility can launch the call of connection independently, but

//     allways utility does it.

//------------------------------------------------------------------------------------------------------

switch(connseq)

{

switch(connseq)

#ifndef _LIAPP_CLIENT_

case 1:…                                                  //Connection

case 4:…                                                  //ExistConnection

#endif

case 2:….

case 3:…

default:…

}

4.3.   DEVID

//-----------------------------------------------------------------------------------------------------

//     Line 709 in the LIAPP.c

//     DEVID.ID[i] is a char, but we find that XI1000_WLA_NETNO is changed from

//     int to char

//------------------------------------------------------------------------------------------------------

typedef struct{

       char length;

       char ID[16];                                      //last char implies network interface    

} DEVID;

… … …

extern int XI1000_WLA_NETNO;

… … …

devid.ID[15]=XI1000_WLA_NETNO;      //XI1000_WLA_NETNO, WLA side to send

4.4.   How to Build the MIB MAP 4.5.   Element Value

//------------------------------------------------------------------------------------------------------------

//     From the implementation of APU, we can find that if Element Value is define as an ID, then

//     the APU can not explain it.

//------------------------------------------------------------------------------------------------------------

For example:

Change linestrcpy(temp,(char *)&xi1500_data[i].BDEVDESC.name); (line 807, Main.cpp) into linestrcpy(temp,(char *)&xi1500_data[i].BDEVDESC. manufacturer);, then you will find that if you click the browse button, the caption of bitmap will disappear. And also change into strcpy(temp,(char *)"CCC");  the caption will appear too.

 

Following the flow of the QureyMIB(), we will find that MIB_GenMap[i] points the address of the element that we want to get.

5.     LIAPP Enhanced 5.1.   APIs 5.1.1.    DIR Request and Response

API:

LIAPP_STATUS  LIAPP_Dir(…)

Functions Related:

       static void Ind_DirReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_DirRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

5.1.2.    File Seek Request and Response

API:

LIAPP_STATUS  LIAPP_Fseek(…)

Functions Related:

       static void Ind_FseekReq(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

static void Ind_FseekRsp(DEVID *,LIAPP_HEADER *,char *body,int bodylen);

5.2.   MIB Structure

Note:Not fit the application now.See MIBTLV.h

AP_CONFIG

{

       0     wla_if_no

       1     wla_ifp[MAX_NO_WIFACE]

CFG_uTYPE(0x1001, u_char, channel, ATT_RW)

CFG_aTYPE(0x1002, u_char, 32+1, essid, ATT_RW)

CFG_aTYPE(0x1016, u_char, 60, TxPwr_status, ATT_RW)

CFG_uTYPE(0x1003, u_char, min_basic_rate, ATT_RW)

CFG_uTYPE(0x1004, u_char, max_basic_rate, ATT_RW)

CFG_uTYPE(0x1005, u_char, type, ATT_RW)

CFG_uTYPE(0x1006, u_char, llc_type, ATT_RW)

CFG_uTYPE(0x1007, u_short, rts_threshold, ATT_RW)

CFG_uTYPE(0x1008, u_char, use_wep, ATT_RW)

CFG_uTYPE(0x1009, u_char, wep_key_no, ATT_RW)

CFG_aTYPE(0x100A, u_char, 6, peer_addr, ATT_RW)

CFG_uTYPE(0x100B, u_short, frag_threshold, ATT_RW)

CFG_aTYPE(0x100C, u_char, 32+1, wep_key1, ATT_RW)

CFG_aTYPE(0x100D, u_char, 32+1, wep_key2, ATT_RW)

CFG_aTYPE(0x100E, u_char, 32+1, wep_key3, ATT_RW)

CFG_aTYPE(0x100F, u_char, 32+1, wep_key4, ATT_RW)

CFG_uTYPE(0x1010, u_char, sta_tx_rate, ATT_RW)

CFG_uTYPE(0x1011, u_short, retry_limit, ATT_RW)

CFG_uTYPE(0x1012, u_short, preamble, ATT_RW)

CFG_uTYPE(0x1013, u_short, diversity, ATT_RW)

CFG_uTYPE(0x1014, u_char, basic_rates, ATT_RW)

CFG_uTYPE(0x1015, u_char, supported_rates, ATT_RW)

CFG_uTYPE(0x1017, u_short, MDCControl, ATT_RW)

CFG_aTYPE(0x1018, u_char, 2+1, CountryCode, ATT_RW)

CFG_aTYPE(0x1019, u_char, 1, Environment, ATT_RW)

CFG_uTYPE(0x1020, u_short, TXPowerMax, ATT_RW)

CFG_aTYPE(0x1021, u_char, 6+1,PxPDestAddr, ATT_RW)

       2     ip

CFG_uTYPE(0x1101, u_char, boot_type, ATT_RW)

CFG_uTYPE(0x1102, struct in_addr, ipaddr, ATT_RW)

CFG_uTYPE(0x1103, struct in_addr, gateway, ATT_RW)

CFG_uTYPE(0x1104, struct in_addr, mask, ATT_RW)

CFG_uTYPE(0x1105, u_char, boot_mode, ATT_RW)

CFG_uTYPE(0x1106, struct in_addr, ipaddr2, ATT_RW)

CFG_uTYPE(0x1107, struct in_addr, gateway2, ATT_RW)

CFG_uTYPE(0x1108, struct in_addr, mask2, ATT_RW)

CFG_uTYPE(0x1109, u_char, boot_mode2, ATT_RW)

CFG_uTYPE(0x110A, u_char, router_mode, ATT_RW)

CFG_uTYPE(0x110B, u_char, nat_port, ATT_RW)

CFG_aTYPE(0x110D, u_char, NFPISZ*SNFPSZ, snat, ATT_RW)

CFG_uTYPE(0x110E, u_char, network_mode, ATT_RW)

CFG_uTYPE(0x110F, u_char, DGWoI, ATT_RW)

       3     route

CFG_aTYPE(0x1801,u_char, MAX_RT_NUM*sizeof(struct in_addr)  , smask, ATT_RW)

CFG_aTYPE(0x1802,u_char, MAX_RT_NUM*sizeof(struct in_addr)  , gaddr, ATT_RW)

CFG_aTYPE(0x1800,u_char,MAX_RT_NUM*sizeof(struct in_addr)  , saddr, ATT_RW)

       4     dhcpd

CFG_uTYPE(0x1500, u_char, dhcpd_port, ATT_RW)

CFG_uTYPE(0x1501, struct in_addr, ipstart, ATT_RW)

CFG_uTYPE(0x1502, struct in_addr, ipend, ATT_RW)

CFG_uTYPE(0x1503, u_char, dhcp_mask_auto, ATT_RW)

CFG_uTYPE(0x1504, struct in_addr, dhcp_mask, ATT_RW)

CFG_uTYPE(0x1505, u_char, dhcp_gateway_auto, ATT_RW)

CFG_uTYPE(0x1506, struct in_addr, dhcp_gateway, ATT_RW)

CFG_uTYPE(0x1507, u_char, dhcp_dns1_auto, ATT_RW)

CFG_uTYPE(0x1508, struct in_addr, dhcp_dns1, ATT_RW)

CFG_uTYPE(0x1509, u_char, dhcp_dns2_auto, ATT_RW)

CFG_uTYPE(0x150A, struct in_addr, dhcp_dns2, ATT_RW)

CFG_uTYPE(0x150B, u_char, dhcp_wins1_auto, ATT_RW)

CFG_uTYPE(0x150C, struct in_addr, dhcp_wins1, ATT_RW)

CFG_uTYPE(0x150D, u_char, dhcp_wins2_auto, ATT_RW)

CFG_uTYPE(0x150E, struct in_addr, dhcp_wins2, ATT_RW)

// Kevin 010702: add persistent DNS/WINS settings in DHCP wizard

CFG_uTYPE(0x150F, struct in_addr, dhcp_dns1_save, ATT_RW)

CFG_uTYPE(0x1510, struct in_addr, dhcp_dns2_save, ATT_RW)

CFG_uTYPE(0x1511, struct in_addr, dhcp_wins1_save, ATT_RW)

CFG_uTYPE(0x1512, struct in_addr, dhcp_wins2_save, ATT_RW)

       5     snmp

CFG_aTYPE(0x1401, u_char, 127+1, sys_contact, ATT_RW)

CFG_aTYPE(0x1402, u_char, 127+1, sys_descr, ATT_RW)

CFG_aTYPE(0x1403, u_char, 127+1, sys_location, ATT_RW)

CFG_uTYPE(0x1404, struct in_addr, manager1_ipaddr, ATT_RW)

CFG_aTYPE(0x1405, u_char, 32+1, community, ATT_RW)

CFG_uTYPE(0x1406, struct in_addr, manager2_ipaddr, ATT_RW)

       6     mgmt

CFG_aTYPE(0x1201, u_char, 32+1, adm_passwd, ATT_RW)

CFG_aTYPE(0x1202, u_char, 32+1, apname, ATT_RW)

CFG_aTYPE(0x1203, u_char, 32+1, adm_name, ATT_RO)

CFG_uTYPE(0x1204, u_short, http_port, ATT_RW)

CFG_uTYPE(0x1205, u_short, telnet_port, ATT_RW)

CFG_aTYPE(0x1206, u_char, 12+1, root_passwd, ATT_RW)

       7    var

CFG_uTYPE(0x1301, u_short, acktime, ATT_RW)

//CFG_uTYPE(0x1302, u_short, xi1000mode, ATT_RW)

CFG_uTYPE(0x1303, u_short, echosvr, ATT_RW)

CFG_uTYPE(0x1304, u_short, always_dhcps, ATT_RW)

CFG_uTYPE(0x1305, u_char, lan_speed, ATT_RW)

CFG_uTYPE(0x1306, u_char, wla_reset, ATT_RW)

CFG_uTYPE(0x1307, u_short, time_wlareset, ATT_RW)

CFG_uTYPE(0x1308, u_short, time_wakeup, ATT_RW)

CFG_uTYPE(0x1309, u_short, wla_cardtype, ATT_RW)

CFG_uTYPE(0x1309, u_char, wla_cardtype, ATT_RW)

CFG_uTYPE(0x1310, u_short, time_stadisasso, ATT_RW)

CFG_uTYPE(0x1311, u_short, wla_typechange, ATT_RW)

CFG_uTYPE(0x1312, u_short, telnet_timeout, ATT_RW)

CFG_uTYPE(0x1313, u_char, wla_stacommblock, ATT_RW)

CFG_uTYPE(0x1314, u_char, Hidden_AP, ATT_RW)

       8    access

                     CFG_uTYPE(0x1600, u_char, enable_access_ctrl, ATT_RW)

       9    pppoe

CFG_uTYPE(0x1700, u_char, enable_pppoe, ATT_RW)

CFG_aTYPE(0x1701, u_char, 32+1, pppoe_user, ATT_RW)

CFG_aTYPE(0x1702, u_char, 32+1, pppoe_passwd, ATT_RW)

CFG_uTYPE(0x1703, u_char, pppoe_cm, ATT_RW)

CFG_uTYPE(0x1704, u_short, pppoe_cm_idle, ATT_RW)

CFG_aTYPE(0x1705, u_char, 127+1, pppoe_user_long, ATT_RW)

       10   radius

CFG_uTYPE(0x2100, u_char, enable_user_auth_ctrl, ATT_RW)

CFG_uTYPE(0x2101, u_char, enable_account_ctrl, ATT_RW)

CFG_uTYPE(0x2102, struct in_addr, auth_ipaddr, ATT_RW)

CFG_uTYPE(0x2103, u_short, auth_port, ATT_RW)

CFG_aTYPE(0x2104, u_char,16+1,auth_secret, ATT_RW)

CFG_uTYPE(0x2105, u_short, reauth_period, ATT_RW)

CFG_uTYPE(0x2106, struct in_addr, account_ipaddr, ATT_RW)

CFG_uTYPE(0x2107, u_short, account_port, ATT_RW)

CFG_aTYPE(0x2108, u_char,16+1,account_secret, ATT_RW)

CFG_uTYPE(0x2109, u_long,sessionid_h, ATT_RW)

11       throughputctl

CFG_uTYPE(0x2301, u_long,allclient_up, ATT_RW)

CFG_uTYPE(0x2302, u_long,allclient_down, ATT_RW)

CFG_uTYPE(0x2303, u_long,allclient_total, ATT_RW)

}

5.3.   EID Display

//----------------------------------------------------------------------------------------------------------------

// AP System Configuration Object

//----------------------------------------------------------------------------------------------------------------

#define U8     unsigned char               //1 byte

#define U16   unsigned short                     //2 bytes

#define U32   unsigned long                //4 bytes

 

#define ATT_NA 0  //not used

#define ATT_RO 1  //read only

#define ATT_WO 2 //write only

#define ATT_RW 3 //full access

 

#define TLV_CTRL(id, vname, scale, att)  {id, sizeof(mibAP##.##vname), (uint8*)&(mibAP##.##vname), scale, att}

 

#define END_TAG 0xffff

#define END_TLV { END_TAG, 0, 0, FALSE,ATT_NA}

// TLV struct define

 

typedef struct _mib_tlv_ctrl

{

       uint16            tag;  // global unique ID for this variable

       uint8              size; // size (in byte) of this variable

       uint8              *ptr;       // offset in the struct which contains this  variable

       Boolean            scale;  // scale type or byte stream

       uint8      attr;

} mib_tlv_ctrl;

// MIB TLV array define

 

//mib_AP_t *pMibAp =

 

static mib_tlv_ctrl   mib_tlv[] =

{

//-----------------------------------------------------------------------------------------------------------

//    Following is defined to fit the XG580PLUS by Mitch

//     Main structure is similar as the Web UI

//

//     #define U8     unsigned char               //1 byte

//     #define U16   unsigned short                     //2 bytes

//     #define U32   unsigned long                //4 bytes  

//

//     Format:TLV_CTRL(id,vname,scale,att)

//

//TLV_CTRL( id,          vname,          scale,      att    )      //Type            Length    Description

//-----------------------------------------------------------------------------------------------------------

//browse

TLV_CTRL(   EID_manufacturer_id,manufacturer_id,       FALSE,   ATT_RO),//u8        40

TLV_CTRL(   EID_product_id, product_id, FALSE,   ATT_RO),      //u8         20

TLV_CTRL(   EID_model_id,      model_id,       FALSE,   ATT_RO),      //u8         20

TLV_CTRL(   EID_devName,      devName,       false,       ATT_RW),      //u8         20

TLV_CTRL(   EID_detail_id,       detail_id,  FALSE,   ATT_RO),      //u8         100

 

//Common  

TLV_CTRL(   EID_username,     username,       FALSE,   ATT_RO),      //u8         20

TLV_CTRL(   EID_password,     password,      TRUE,    ATT_RW),      //u8         20

 

//Information

//Information -> General

TLV_CTRL(   EID_EthMacAddr,  EthMacAddr,  false,       ATT_RO),      //u8         6    

/*

TLV_CTRL(   EID_FWMajor,      FWMajor,       true, ATT_RO),      //u16              1     FW:Fireware

TLV_CTRL(   EID_FWMiddle,     FWMiddle,     true, ATT_RO),      //u16              1

TLV_CTRL(   EID_FWMinor,      FWMinor,       true, ATT_RO),      //u16              1

*/

TLV_CTRL(   EID_Version,  Version,   false,       ATT_RO),      //u8         40    //for the future

/*

TLV_CTRL(   EID_WebMajor,     WebMajor,      true, ATT_RO),      //u16              1    

TLV_CTRL(   EID_WebMiddle,    WebMiddle,    true, ATT_RO),      //u16              1

TLV_CTRL(   EID_WebMinor,     WebMinor,      true, ATT_RO),      //u16              1

*/

TLV_CTRL(   EID_WebVersion,   WebVersion,    false,       ATT_RO),      //u8         40    //for the future

 

//Configuration

//Configuration -> General

TLV_CTRL(   EID_devName,      devName,       false,       ATT_RW),      //u8         20

TLV_CTRL(   EID_WirelessMode,WirelessMode,       true, ATT_RW),      //u16              1    

TLV_CTRL(   EID_NetworkType,NetworkType, true, ATT_RW),      //u16              1    

TLV_CTRL(   EID_DesiredSsId,DesiredSsId,     false,       ATT_RW),      //u8         20

TLV_CTRL(   EID_CurrRFChan,  CurrRFChan,  false,       ATT_RW),      //u16              1     Current RF Channel

TLV_CTRL(   EID_apMode, apMode,         false,       ATT_RW),      //u16              1     1.B only mode 2.G only mode 3.B/G Mixed Mode

TLV_CTRL(   EID_TxRate,  TxRate,          true, ATT_RW),      //u16              1     1.Auto            2.1 2 5.5….54

TLV_CTRL(   EID_countrycode,countrycode,    true, ATT_RW),      //u16              1    

 

//Configuration -> Security

TLV_CTRL(   EID_WEPMode,    WEPMode,     true, ATT_RW),      //U16             1

TLV_CTRL(   EID_AuthType,     AuthType,      true, ATT_RW),      //u16              1     Auth:Authentication

TLV_CTRL(   EID_WpaPsk, WpaPsk,        false,       ATT_RW),      //u8         20

TLV_CTRL(   EID_askey,     askey,            true, ATT_RW),      //u16              1     Key Format: 1.ASCII 2.HEX

//  TLV_CTRL(     EID_Passphrase,    Passphrase,    false,       ATT_RW),      //u8         20

TLV_CTRL(   EID_WepDefaultKeyValue1,\

                                WepDefaultKeyValue1,   false,       ATT_RW),//u8              20

TLV_CTRL(   EID_WepDefaultKeyValue2,\ 

                                WepDefaultKeyValue2,   false,       ATT_RW),//u8              20   

TLV_CTRL(   EID_WepDefaultKeyValue3,\

                                WepDefaultKeyValue3,   false,       ATT_RW),//u8              20

TLV_CTRL(   EID_WepDefaultKeyValue4,\

                                WepDefaultKeyValue4,   false,       ATT_RW),//u8              20

 

//Configuration -> Access Control

TLV_CTRL(   EID_macCloneEnable,macCloneEnable,       true, ATT_RW),//u16            1    

TLV_CTRL(   EID_wlanfiltermode,wlanfiltermode,     false,       ATT_RW),//u16            1     AC:Access Control

 

//Configuration -> Parameter Log

 

//TCP/IP

//TCP/IP -> General

TLV_CTRL(   EID_EnableDHCP,  EnableDHCP,  true, ATT_RW),      //u16              1

TLV_CTRL(   EID_IPAddr,   IPAddr,          false,       ATT_RW),      //u8         4

TLV_CTRL(   EID_SubnetMask,  SubnetMask,   false,       ATT_RW),      //u8         4    

TLV_CTRL(   EID_GwyAddr,      GwyAddr,      false,       ATT_RW),      //u8         4     Gwy:Gateway

 

//Statistics

//Statistics -> Status

 

//Statistics -> Statistics

TLV_CTRL(   EID_EthInPkt,       EthInPkt, true, ATT_RW),      //u32              1     Ethernet In Packet

TLV_CTRL(   EID_EthOutPkt,     EthOutPkt,     true, ATT_RW),      //u32              1     Ethernet Out Packet

 

//Statistics -> AP Browser

   

END_TLV

};

 

 

 

 

本文地址:http://com.8s8s.com/it/it34108.htm