应用框架(AF)

http://blog.163.com/ssou_1985/blog/static/2953203620121012112749593/


应用框架(AF)


应用框架层是应用道APS层的OTA数据接口。此层也接收数据消息的终端多路复用器。AF为应用提供以下功能:


·                     终端(Endpoint)管理


·                     发送和接收数据


哈哈,这里的函数应该就是我们经常要用到的函数了。


终端管理


每个设备都是Zigbee中的节点,每个节点有长地址和短地址,短地址被其他设备用来发送数据。每个节点又241个终端(0保留,1-240 可分配给应用)。每个终端可以独立设置地址;当设备发送数据时必须指定目标设备的短地址和接收终端。一个应用必须注册一个或多个终端用来接收或者发送数据。


简单描述符-SimpleDescriptionFormat_t


每个终端都必须有一个Zigbee简单描述。这些描述对Zigbee网络刻画了这个终端,其他设备可以询问这个终端以知道这个设备的类型。


typedef struct


{


  byte          EndPoint;


  uint16        AppProfId;


  uint16        AppDeviceId;


  byte          AppDevVer:4;


  byte          Reserved:4;             // AF_V1_SUPPORT uses for AppFlags:4.


  byte          AppNumInClusters;


  cId_t         *pAppInClusterList;


  byte          AppNumOutClusters;


  cId_t         *pAppOutClusterList;


} SimpleDescriptionFormat_t;


EndPoint  终端号:1-240 这是节点的子地址,用来接收数据


AppProfId  定义了这个终端上支持的Profile ID(剖面ID), ID最好遵循由ZigBee联盟的分配。


AppDeviceId 终端支持的设备ID,ID最好遵循ZigBee联盟的分配。


AppDevVer 此终端上设备执行的设备描述的版本:0x00为Version 1.0.


Reserved  保留


AppNumInClusters  终端支持的输入簇数目


pAppInClusterList  指向输入Cluster ID列表的指针


AppNumOutClusters  终端支持的输出簇数目


pAppOutClusterList  指向输出Cluster ID列表的指针


终端描述符-endPointDesc_t


节点中的每一个终端都必须有一个终端描述符


typedef struct


{


  byte endPoint;


  byte *task_id;  // Pointer to location of the Application task ID.


  SimpleDescriptionFormat_t *simpleDesc;


  afNetworkLatencyReq_t latencyReq;


} endPointDesc_t;


task_id -任务ID指针,当接收到消息时,此任务ID将指示消息传递目的。接收到的消息是以OSAL消息形式包装的,将发送到一个任务


simpleDesc  -指向这个终端的ZigBee简单描述


latencyReq  -必须用noLatencyReqs来填充


afStatus_t afRegister( endPointDesc_t *epDesc );


为设备注册一个新的终端


epDesc      -指向终端描述符


返回值:afStatus_t   -若成功则返回ZSuccess,否则返回ZComDef.h中定义的错误


epList_t *afRegisterExtended( endPointDesc_t *epDesc, pDescCB descFn );


在上面函数功能的基础上增加了回调函数,当终端的简单描述符被查询时将调用此回调函数。这样应有就可以动态改变简单描述符而不用RAM/ROM来储存描述符了。


descFn      -回调函数指针。相关函数必须为简单描述符分配足够的空间,填充简单描述符,然后返回指向简单描述符的指针,调用者将释放为描述符分配空间。


epList      -指向终端列表元件的指针,如果失败则为NULL


endPointDesc_t *afFindEndPointDesc( byte endPoint );


从一个终端找到终端描述符


endPoint    -要寻找的终端描述符的终端号


endPointDesc_t -指向终端描述符的指针,若失败则为NULL


byte afFindSimpleDesc( SimpleDescriptionFormat_t **ppDesc, byte EP );


从一个终端找到终端描述符。若返回值非零则必须调用osal_mem_free()来释放描述符的内存占用。


ppDesc  -指向指向简单描述符的指针。


EP 终端简单描述符需要


uint8 afGetMatch( uint8 ep );


默认情况下,设备将响应ZDO匹配描述符请求。用这个函数来获得ZDO匹配描述符应答的设置。


ep  -用来获得ZDO匹配描述符响应行为的终端


返回值:TRUE-允许响应,FALSE-不允许或者终端未找到


uint8 afSetMatch( uint8 ep, uint8 action );


默认情况下,设备将响应ZDO匹配描述符。可以用这个函数来改变这个行为,比如ep为1,action为FALSE,ZDO将不响应终端1的ZDO匹配面述符请求。


ep  -用来获得ZDO匹配描述符响应行为的终端


action  -TRUE-允许响应,FALSE-不允许或者终端未找到


返回值:TRUE-成功,FALSE-失败或者终端未找到


byte afNumEndPoints( void );


查找已注册的终端数目,返回此设备上已注册的终端数目,包括终端0


void afEndPoints( byte *epBuf, byte skipZDO );


返回包含已注册的终端的一个数组。


epBuf  指向存放终端的数组,每个终端占一个字节  


skipZDO -设置为TRUE,则不包含ZDO终端(终端0)


发送数据


afStatus_t AF_DataRequest( afAddrType_t *dstAddr, endPointDesc_t *srcEP,


                uint16 cID, uint16 len, uint8 *buf, uint8 *transID,


                uint8 options, uint8 radius );


dstAddr -目标地址指针。


    afAddrNotPresent    由反射器(邦定源,也即路由器或者协调器)指定


    afAddrGroup     发送到组


    afAddrBroadcast 发送广播消息


    afAddr16Bit     直接发送到节点(单播)


srcEP       -发送终端的终端描述符指针


cID     -簇ID,cluster ID如同消息ID,并且在剖面(profile)中各不相同


len     -要发送的字节数


buf     -指向要发送的数据缓存的指针


transID -事务序列号指针。如果消息缓存发送,这个函数将增加这个数字


options     -发送选项,可以由下面一项,或几项相或得到


    AF_ACK_REQUEST 0x10 要求APS应答,这是应用层的应答,支在直接发送(单播)时使用。


    AF_DISCV_ROUTE 0x20 总要包含这个选项


    AF_SKIP_ROUTING 0x80 设置这个选项将导致设备跳过路由而直接发送消息。终点设备将不向其父亲发送消息。在直接发送(单播)和广播消息时很好用。


radius  最大的跳数,用默认值AF_DEFAULT_RADIUS


afStatus_t  成功则为ZSuccess(defined in ZComDef.h). 否则 Errors(defined in ZComDef.h)


uint8 afDataReqMTU( afDataReqMTU_t* fields );


找出基于输入参数的最大可发送字节数,返回能发送的最大字节数


fields      -要发送的消息类型参数


    typedef struct


    {


        uint8              kvp;


        APSDE_DataReqMTU_t aps;


    } afDataReqMTU_t;


    kvp  设为false.


    typedef struct


    {


        uint8 secure;


    } APSDE_DataReqMTU_t;


    aps.secure   设为false.如果在一个安全网络中此位将自动设置.   
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值