zcl_ss.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568
  1. /**************************************************************************************************
  2. Filename: zcl_ss.h
  3. Revised: $Date: 2010-02-09 15:28:14 -0800 (Tue, 09 Feb 2010) $
  4. Revision: $Revision: 21679 $
  5. Description: This file contains the ZCL Security and Safety definitions.
  6. Copyright 2006-2010 Texas Instruments Incorporated. All rights reserved.
  7. IMPORTANT: Your use of this Software is limited to those specific rights
  8. granted under the terms of a software license agreement between the user
  9. who downloaded the software, his/her employer (which must be your employer)
  10. and Texas Instruments Incorporated (the "License"). You may not use this
  11. Software unless you agree to abide by the terms of the License. The License
  12. limits your use, and you acknowledge, that the Software may not be modified,
  13. copied or distributed unless embedded on a Texas Instruments microcontroller
  14. or used solely and exclusively in conjunction with a Texas Instruments radio
  15. frequency transceiver, which is integrated into your product. Other than for
  16. the foregoing purpose, you may not use, reproduce, copy, prepare derivative
  17. works of, modify, distribute, perform, display or sell this Software and/or
  18. its documentation for any purpose.
  19. YOU FURTHER ACKNOWLEDGE AND AGREE THAT THE SOFTWARE AND DOCUMENTATION ARE
  20. PROVIDED “AS IS” WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED,
  21. INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY, TITLE,
  22. NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL
  23. TEXAS INSTRUMENTS OR ITS LICENSORS BE LIABLE OR OBLIGATED UNDER CONTRACT,
  24. NEGLIGENCE, STRICT LIABILITY, CONTRIBUTION, BREACH OF WARRANTY, OR OTHER
  25. LEGAL EQUITABLE THEORY ANY DIRECT OR INDIRECT DAMAGES OR EXPENSES
  26. INCLUDING BUT NOT LIMITED TO ANY INCIDENTAL, SPECIAL, INDIRECT, PUNITIVE
  27. OR CONSEQUENTIAL DAMAGES, LOST PROFITS OR LOST DATA, COST OF PROCUREMENT
  28. OF SUBSTITUTE GOODS, TECHNOLOGY, SERVICES, OR ANY CLAIMS BY THIRD PARTIES
  29. (INCLUDING BUT NOT LIMITED TO ANY DEFENSE THEREOF), OR OTHER SIMILAR COSTS.
  30. Should you have any questions regarding your right to use this Software,
  31. contact Texas Instruments Incorporated at www.TI.com.
  32. **************************************************************************************************/
  33. #ifndef ZCL_SS_H
  34. #define ZCL_SS_H
  35. #ifdef __cplusplus
  36. extern "C"
  37. {
  38. #endif
  39. /*********************************************************************
  40. * INCLUDES
  41. */
  42. #include "zcl.h"
  43. /*********************************************************************
  44. * CONSTANTS
  45. */
  46. /************************************/
  47. /*** IAS Zone Cluster Attributes ***/
  48. /************************************/
  49. // Zone Information attributes set
  50. #define ATTRID_SS_IAS_ZONE_STATE 0x0000
  51. #define ATTRID_SS_IAS_ZONE_TYPE 0x0001
  52. #define ATTRID_SS_IAS_ZONE_STATUS 0x0002
  53. /*** Zone State Attribute values ***/
  54. #define SS_IAS_ZONE_STATE_NOT_ENROLLED 0x00
  55. #define SS_IAS_ZONE_STATE_ENROLLED 0x01
  56. /*** Zone Type Attribute values ***/
  57. #define SS_IAS_ZONE_TYPE_STANDARD_CIE 0x0000
  58. #define SS_IAS_ZONE_TYPE_MOTION_SENSOR 0x000D
  59. #define SS_IAS_ZONE_TYPE_CONTACT_SWITCH 0x0015
  60. #define SS_IAS_ZONE_TYPE_FIRE_SENSOR 0x0028
  61. #define SS_IAS_ZONE_TYPE_WATER_SENSOR 0x002A
  62. #define SS_IAS_ZONE_TYPE_GAS_SENSOR 0x002B
  63. #define SS_IAS_ZONE_TYPE_PERSONAL_EMERGENCY_DEVICE 0x002C
  64. #define SS_IAS_ZONE_TYPE_VIBRATION_MOVEMENT_SENSOR 0x002D
  65. #define SS_IAS_ZONE_TYPE_REMOTE_CONTROL 0x010F
  66. #define SS_IAS_ZONE_TYPE_KEY_FOB 0x0115
  67. #define SS_IAS_ZONE_TYPE_KEYPAD 0x021D
  68. #define SS_IAS_ZONE_TYPE_STANDARD_WARNING_DEVICE 0x0225
  69. #define SS_IAS_ZONE_TYPE_INVALID_ZONE_TYPE 0xFFFF
  70. /*** Zone Status Attribute values ***/
  71. #define SS_IAS_ZONE_STATUS_ALARM1_ALARMED 0x0001
  72. #define SS_IAS_ZONE_STATUS_ALARM2_ALARMED 0x0002
  73. #define SS_IAS_ZONE_STATUS_TAMPERED_YES 0x0004
  74. #define SS_IAS_ZONE_STATUS_BATTERY_LOW 0x0008
  75. #define SS_IAS_ZONE_STATUS_SUPERVISION_REPORTS_YES 0x0010
  76. #define SS_IAS_ZONE_STATUS_RESTORE_REPORTS_YES 0x0020
  77. #define SS_IAS_ZONE_STATUS_TROUBLE_YES 0x0040
  78. #define SS_IAS_ZONE_STATUS_AC_MAINS_FAULT 0x0080
  79. // Zone Settings attributes set
  80. #define ATTRID_SS_IAS_CIE_ADDRESS 0x0010
  81. // commands:
  82. #define COMMAND_SS_IAS_ZONE_STATUS_CHANGE_NOTIFICATION 0x00
  83. #define COMMAND_SS_IAS_ZONE_STATUS_ENROLL_REQUEST 0x01
  84. #define COMMAND_SS_IAS_ZONE_STATUS_ENROLL_RESPONSE 0x00
  85. // permitted values for Enroll Response Code field
  86. #define SS_IAS_ZONE_STATUS_ENROLL_RESPONSE_CODE_SUCCESS 0x00
  87. #define SS_IAS_ZONE_STATUS_ENROLL_RESPONSE_CODE_NOT_SUPPORTED 0x01
  88. #define SS_IAS_ZONE_STATUS_ENROLL_RESPONSE_CODE_NO_ENROLL_PERMIT 0x02
  89. #define SS_IAS_ZONE_STATUS_ENROLL_RESPONSE_CODE_TOO_MANY_ZONES 0x03
  90. /************************************/
  91. /*** IAS ACE Cluster Attributes ***/
  92. /************************************/
  93. // cluster has no attributes
  94. // command IDs received by Server
  95. //note: EMERGENCY, FIRE,PANIC, GET_ZONE_ID_MAP cmds have no payload
  96. #define COMMAND_SS_IAS_ACE_ARM 0x00
  97. #define COMMAND_SS_IAS_ACE_BYPASS 0x01
  98. #define COMMAND_SS_IAS_ACE_EMERGENCY 0x02
  99. #define COMMAND_SS_IAS_ACE_FIRE 0x03
  100. #define COMMAND_SS_IAS_ACE_PANIC 0x04
  101. #define COMMAND_SS_IAS_ACE_GET_ZONE_ID_MAP 0x05
  102. #define COMMAND_SS_IAS_ACE_GET_ZONE_INFORMATION 0x06
  103. // Cmds, generated by Server
  104. #define COMMAND_SS_IAS_ACE_ARM_RESPONSE 0x00
  105. #define COMMAND_SS_IAS_ACE_GET_ZONE_ID_MAP_RESPONSE 0x01
  106. #define COMMAND_SS_IAS_ACE_GET_ZONE_INFORMATION_RESPONSE 0x02
  107. /*** Arm Mode field permitted values ***/
  108. #define SS_IAS_ACE_ARM_DISARM 0x00
  109. #define SS_IAS_ACE_ARM_DAY_HOME_ZONES_ONLY 0x01
  110. #define SS_IAS_ACE_ARM_NIGHT_SLEEP_ZONES_ONLY 0x02
  111. #define SS_IAS_ACE_ARM_ALL_ZONES 0x03
  112. /*** Arm Notification field permitted values ***/
  113. #define SS_IAS_ACE_ARM_NOTIFICATION_ALL_ZONES_DISARMED 0x00
  114. #define SS_IAS_ACE_ARM_NOTIFICATION_DAY_HOME_ZONES_ONLY 0x01
  115. #define SS_IAS_ACE_ARM_NOTIFICATION_NIGHT_SLEEP_ZONES_ONLY 0x02
  116. #define SS_IAS_ACE_ARM_NOTIFICATION_ALL_ZONES_ARMED 0x03
  117. /************************************/
  118. /*** IAS WD Cluster Attributes ***/
  119. /************************************/
  120. // Maximum Duration attribute
  121. #define ATTRID_SS_IAS_WD_MAXIMUM_DURATION 0x0000
  122. // commands:
  123. #define COMMAND_SS_IAS_WD_START_WARNING 0x00
  124. #define COMMAND_SS_IAS_WD_SQUAWK 0x01
  125. /*** warningMode field values ***/
  126. #define SS_IAS_START_WARNING_WARNING_MODE_STOP 0
  127. #define SS_IAS_START_WARNING_WARNING_MODE_BURGLAR 1
  128. #define SS_IAS_START_WARNING_WARNING_MODE_FIRE 2
  129. #define SS_IAS_START_WARNING_WARNING_MODE_EMERGENCY 3
  130. /*** start warning: strobe field values ***/
  131. #define SS_IAS_START_WARNING_STROBE_NO_STROBE_WARNING 0
  132. #define SS_IAS_START_WARNING_STROBE_USE_STPOBE_IN_PARALLEL_TO_WARNING 1
  133. /*** squawkMode field values ***/
  134. #define SS_IAS_SQUAWK_SQUAWK_MODE_SYSTEM_ALARMED_NOTIFICATION_SOUND 0
  135. #define SS_IAS_SQUAWK_SQUAWK_MODE_SYSTEM_DISARMED_NOTIFICATION_SOUND 1
  136. /*** squawk strobe field values ***/
  137. #define SS_IAS_SQUAWK_STROBE_NO_STROBE_SQUAWK 0
  138. #define SS_IAS_SQUAWK_STROBE_USE_STROBE_BLINK_IN_PARALLEL_TO_SQUAWK 1
  139. /*** squawk level field values ***/
  140. #define SS_IAS_SQUAWK_SQUAWK_LEVEL_LOW_LEVEL_SOUND 0
  141. #define SS_IAS_SQUAWK_SQUAWK_LEVEL_MEDIUM_LEVEL_SOUND 1
  142. #define SS_IAS_SQUAWK_SQUAWK_LEVEL_HIGH_LEVEL_SOUND 2
  143. #define SS_IAS_SQUAWK_SQUAWK_LEVEL_VERY_HIGH_LEVEL_SOUND 3
  144. // The maximum number of entries in the Zone table
  145. #define ZCL_SS_MAX_ZONES 256
  146. #define ZCL_SS_MAX_ZONE_ID 254
  147. /*********************************************************************
  148. * TYPEDEFS
  149. */
  150. /*** ZCL IAS Zone Cluster: Zone Status Change Notification Cmd payload ***/
  151. typedef struct
  152. {
  153. uint8 zoneStatus;
  154. uint8 extendedStatus;
  155. } zclCmdSSIASZoneStatusChangeNotification_t;
  156. /*** ZCL IAS Zone Cluster: Zone Enroll Request Cmd payload ***/
  157. typedef struct
  158. {
  159. uint16 zoneType;
  160. uint16 manufacturerCode;
  161. } zclCmdSSIASZoneEnrollRequest_t;
  162. /*** ZCL IAS Zone Cluster: Zone Enroll Response Cmd payload ***/
  163. typedef struct
  164. {
  165. uint8 responseCode;
  166. uint8 zoneID;
  167. } zclCmdSSIASZoneEnrollResponse_t;
  168. /*** typedef for IAS ACE Zone table ***/
  169. typedef struct
  170. {
  171. uint8 zoneID;
  172. uint16 zoneType;
  173. uint8 zoneAddress[8];
  174. } IAS_ACE_ZoneTable_t;
  175. /*** ZCL IAS ACE Cluster: ARM Cmd payload ***/
  176. typedef uint8 zclCmdSSIASACEArmPayload_t;
  177. /*** ZCL IAS ACE Cluster: BYPASS Cmd payload ***/
  178. typedef struct
  179. {
  180. uint8 numZones;
  181. uint8 zoneID[];
  182. } zclCmdSSIASACEBypassPayload_t;
  183. /*** ZCL IAS ACE Cluster: GET_ZONE_INFORNMATION cmd payload: ***/
  184. typedef uint8 zclCmdSSIASACEGetZoneInformationPayload_t;
  185. /*** ZCL IAS ACE Cluster: ARM Response Cmd payload ***/
  186. typedef uint8 zclCmdSSIASACEArmResponsePayload_t;
  187. /*** ZCL IAS ACE Cluster: Get Zone ID Map response Cmd payload ***/
  188. typedef uint16 zclCmdSSIASZoneIDMapSection_t[16];
  189. /*** ZCL IAS ACE Cluster: Get Zone Information Response Cmd payload ***/
  190. typedef struct
  191. {
  192. uint8 zoneID;
  193. uint16 zoneType;
  194. uint8 *ieeeAddress;
  195. } zclCmdSSIASACEGetZoneInformationResponsePayload_t;
  196. /*** ZCL WD Cluster: COMMAND_WD_START_WARNING Cmd payload ***/
  197. typedef struct
  198. {
  199. unsigned int warnMode:4; // Warning Mode
  200. unsigned int warnStrobe:2; // Strobe
  201. unsigned int reserved:2; // Reserved for future use
  202. } warningbits_t;
  203. typedef union
  204. {
  205. warningbits_t warningbits;
  206. uint8 warningbyte;
  207. } warning_t;
  208. typedef struct
  209. {
  210. warning_t warningmessage;
  211. uint16 duration;
  212. } zclCmdSSWDStartWarningPayload_t;
  213. /*** ZCL WD Cluster: COMMAND_WD_SQUAWK Cmd payload ***/
  214. typedef struct
  215. {
  216. unsigned int squawkMode:4;
  217. unsigned int strobe:1;
  218. unsigned int reserved:1;
  219. unsigned int squawkLevel:2;
  220. } squawkbits_t;
  221. typedef union
  222. {
  223. squawkbits_t squawkbits;
  224. uint8 squawkbyte;
  225. } zclCmdSSWDSquawkPayload_t;
  226. /*** Structures used for callback functions ***/
  227. typedef struct
  228. {
  229. uint16 zoneStatus; // current zone status - bit map
  230. uint8 extendedStatus; // bit map, currently set to All zeroes ( reserved )
  231. } zclZoneChangeNotif_t;
  232. typedef struct
  233. {
  234. afAddrType_t *srcAddr; // initiator's address
  235. uint8 zoneID; // allocated zone ID
  236. uint16 zoneType; // current value of Zone Type attribute
  237. uint16 manufacturerCode; // manufacturer Code from node descriptor for the device
  238. } zclZoneEnrollReq_t;
  239. typedef struct
  240. {
  241. uint8 responseCode; // value of response Code
  242. uint8 zoneID; // index to the zone table of the CIE
  243. } zclZoneEnrollRsp_t;
  244. typedef struct
  245. {
  246. uint8 numberOfZones; // number of zones ( one byte)
  247. uint8 *bypassBuf; // zone IDs array of 256 entries one byte each
  248. } zclACEBypass_t;
  249. typedef struct
  250. {
  251. uint8 zoneID; // index to the zone table of the CIE
  252. uint16 zoneType; // value of Zone Type atribute
  253. uint8 *ieeeAddr; // pointer to 64 bit address
  254. } zclACEGetZoneInfoRsp_t;
  255. typedef struct
  256. {
  257. warning_t warnings; // bitfiels ( one byte )
  258. uint16 duration; // warning duration in seconds
  259. } zclWDStartWarning_t;
  260. // This callback is called to process a Change Notification command
  261. // zoneStatus - current zone status - bit map
  262. // extendedStatus - bit map, currently set to All zeroes ( reserved )
  263. typedef void (*zclSS_ChangeNotification_t)( zclZoneChangeNotif_t *pCmd );
  264. // This callback is called to process a Enroll Request command
  265. // srcAddr - initiator's address
  266. // zoneID - allocated zone ID
  267. // zoneType - current value of Zone Type attribute
  268. // manufacturerCode - manufacturer Code from node descriptor for the device
  269. typedef void (*zclSS_EnrollRequest_t)( zclZoneEnrollReq_t *pReq );
  270. // This callback is called to process a Enroll Response command
  271. // responseCode - value of response Code
  272. // zoneID - index to the zone table of the CIE
  273. typedef void (*zclSS_EnrollResponse_t)( zclZoneEnrollRsp_t *pRsp );
  274. // This callback is called to process an Arm command
  275. // armMode - value of arm mode
  276. // returns Arm Notification
  277. typedef uint8 (*zclSS_ACE_Arm_t)( uint8 armMode );
  278. // This callback is called to process a Bypass command
  279. // numberOfZones - number of zones ( one byte)
  280. // bypassBuf - zone IDs array of 256 entries one byte each
  281. typedef void (*zclSS_ACE_Bypass_t)( zclACEBypass_t *pCmd );
  282. // This callback is called to process an Emergency command
  283. // no payload
  284. typedef void (*zclSS_ACE_Emergency_t)( void );
  285. // This callback is called to process a Fire command
  286. // no payload
  287. typedef void (*zclSS_ACE_Fire_t)( void );
  288. // This callback is called to process a Panic command
  289. // no payload
  290. typedef void (*zclSS_ACE_Panic_t)( void );
  291. // This callback is called to process a Get Zone ID Map command
  292. // no payload
  293. typedef void (*zclSS_ACE_GetZoneIDMap_t)( void );
  294. // This callback is called to process a Get Zone Information command
  295. // zoneID - index to the zone table of the CIE
  296. typedef void (*zclSS_ACE_GetZoneInformation_t)( uint8 zoneID );
  297. // This callback is called to process an Arm Response command
  298. // armNotification - value of arm notification field
  299. typedef void (*zclSS_ACE_ArmResponse_t)( uint8 armNotification );
  300. // This callback is called to process a Get Zone ID Map Response command
  301. // pointer to the zone ID Map: table of 16 uint16
  302. typedef void (*zclSS_ACE_GetZoneIDMapResponse_t)( uint16 *zoneIDMap );
  303. // This callback is called to process a Get Zone Information Response command
  304. // zoneID - index to the zone table of the CIE
  305. // zoneType - value of Zone Type atribute
  306. // *ieeeAddr - pointer to 64 bit address
  307. typedef void (*zclSS_ACE_GetZoneInformationResponse_t)( zclACEGetZoneInfoRsp_t *pRsp );
  308. // This callback is called to process a Start Warning command
  309. // warnings - bitfiels ( one byte )
  310. // duration - in seconds
  311. typedef void (*zclSS_WD_StartWarning_t)( zclWDStartWarning_t *pCmd );
  312. // This callback is called to process a Squawk command
  313. // squawks - bitfields ( one byte )
  314. typedef void (*zclSS_WD_Squawk_t)( zclCmdSSWDSquawkPayload_t squawks );
  315. // Register Callbacks table entry - enter function pointers for callbacks that
  316. // the application would like to receive
  317. typedef struct
  318. {
  319. zclSS_ChangeNotification_t pfnChangeNotification; // Change Notification command
  320. zclSS_EnrollRequest_t pfnEnrollRequest; // Enroll Request command
  321. zclSS_EnrollResponse_t pfnEnrollResponse; // Enroll Reponse command
  322. zclSS_ACE_Arm_t pfnACE_Arm; // Arm command
  323. zclSS_ACE_Bypass_t pfnACE_Bypass; // Bypass command
  324. zclSS_ACE_Emergency_t pfnACE_Emergency; // Emergency command
  325. zclSS_ACE_Fire_t pfnACE_Fire; // Fire command
  326. zclSS_ACE_Panic_t pfnACE_Panic; // Panic command
  327. // zclSS_ACE_GetZoneIDMap_t pfnACE_GetZoneIDMap; // Get Zone ID Map command
  328. // zclSS_ACE_GetZoneInformation_t pfnACE_GetZoneInformation; // Get Zone Information Command
  329. zclSS_ACE_ArmResponse_t pfnACE_ArmResponse; // ArmResponse command
  330. zclSS_ACE_GetZoneIDMapResponse_t pfnACE_GetZoneIDMapResponse; // Get Zone ID Map Response command
  331. zclSS_ACE_GetZoneInformationResponse_t pfnACE_GetZoneInformationResponse; // Get Zone Information Response command
  332. zclSS_WD_StartWarning_t pfnWD_StartWarning; // Start Warning command
  333. zclSS_WD_Squawk_t pfnWD_Squawk; // Squawk command
  334. } zclSS_AppCallbacks_t;
  335. /*********************************************************************
  336. * FUNCTION MACROS
  337. */
  338. #ifdef ZCL_ACE
  339. /*
  340. * Send an Emergency Cmd ( IAS ACE Cluster )
  341. * Use like:
  342. * ZStatus_t zclSS_Send_IAS_ACE_EmergencyCmd( uint16 srcEP, afAddrType_t *dstAddr, uint8 disableDefaultRsp, uint8 seqNum );
  343. */
  344. #define zclSS_Send_IAS_ACE_EmergencyCmd(a,b,c,d) zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SS_IAS_ACE,\
  345. COMMAND_SS_IAS_ACE_EMERGENCY, TRUE,\
  346. ZCL_FRAME_CLIENT_SERVER_DIR, (c), 0, (d), 0, NULL )
  347. /*
  348. * Send a Fire Cmd ( IAS ACE Cluster )
  349. * Use like:
  350. * ZStatus_t zclSS_Send_IAS_ACE_FireCmd( uint16 srcEP, afAddrType_t *dstAddr, uint8 disableDefaultRsp, uint8 seqNum );
  351. */
  352. #define zclSS_Send_IAS_ACE_FireCmd(a,b,c,d) zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SS_IAS_ACE,\
  353. COMMAND_SS_IAS_ACE_FIRE, TRUE,\
  354. ZCL_FRAME_CLIENT_SERVER_DIR, (c), 0, (d), 0, NULL )
  355. /*
  356. * Send a Panic Cmd ( IAS ACE Cluster )
  357. * Use like:
  358. * ZStatus_t zclSS_Send_IAS_ACE_PanicCmd( uint16 srcEP, afAddrType_t *dstAddr, uint8 disableDefaultRsp, uint8 seqNum );
  359. */
  360. #define zclSS_Send_IAS_ACE_PanicCmd(a,b,c,d) zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SS_IAS_ACE,\
  361. COMMAND_SS_IAS_ACE_PANIC, TRUE,\
  362. ZCL_FRAME_CLIENT_SERVER_DIR, (c), 0, (d), 0, NULL )
  363. /*
  364. * Send a GetZoneIDMap Cmd ( IAS ACE Cluster )
  365. * Use like:
  366. * ZStatus_t zclSS_Send_IAS_ACE_GetZoneIDMapCmd( uint16 srcEP, afAddrType_t *dstAddr, uint8 disableDefaultRsp, uint8 seqNum );
  367. */
  368. #define zclSS_Send_IAS_ACE_GetZoneIDMapCmd(a,b,c,d) zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SS_IAS_ACE,\
  369. COMMAND_SS_IAS_ACE_GET_ZONE_ID_MAP, TRUE,\
  370. ZCL_FRAME_CLIENT_SERVER_DIR, (c), 0, (d), 0, NULL )
  371. #endif // ZCL_ACE
  372. /*********************************************************************
  373. * VARIABLES
  374. */
  375. /*********************************************************************
  376. * FUNCTIONS
  377. */
  378. /*
  379. * Register for callbacks from this cluster library
  380. */
  381. extern ZStatus_t zclSS_RegisterCmdCallbacks( uint8 endpoint, zclSS_AppCallbacks_t *callbacks );
  382. #ifdef ZCL_ZONE
  383. /*
  384. * Call to send out a Change Notification Command
  385. * zoneStatus - current zone status - bit map
  386. * extendedStatus - bit map, currently set to All zeros ( reserved)
  387. */
  388. extern ZStatus_t zclSS_IAS_Send_ZoneStatusChangeNotificationCmd( uint8 srcEP, afAddrType_t *dstAddr,
  389. uint16 zoneStatus, uint8 extendedStatus,
  390. uint8 disableDefaultRsp, uint8 seqNum );
  391. /*
  392. * Call to send out a Enroll Request Command
  393. * zoneType - current value of Zone Type attribute
  394. * manufacturerCode - manufacturer Code from node descriptor for the device
  395. */
  396. extern ZStatus_t zclSS_IAS_Send_ZoneStatusEnrollRequestCmd( uint8 srcEP, afAddrType_t *dstAddr,
  397. uint16 zoneType, uint16 manufacturerCode,
  398. uint8 disableDefaultRsp, uint8 seqNum );
  399. /*
  400. * Call to send out a Enroll Response Command
  401. * responseCode - value of response Code
  402. * zoneID - index to the zone table of the CIE
  403. */
  404. extern ZStatus_t zclSS_IAS_Send_ZoneStatusEnrollResponseCmd( uint8 srcEP, afAddrType_t *dstAddr,
  405. uint8 responseCode, uint8 zoneID,
  406. uint8 disableDefaultRsp, uint8 seqNum );
  407. #endif // ZCL_ZONE
  408. #ifdef ZCL_ACE
  409. /*
  410. * Call to send out a Arm Command ( IAS ACE Cluster )
  411. * armMode - uint8
  412. */
  413. extern ZStatus_t zclSS_Send_IAS_ACE_ArmCmd( uint8 srcEP, afAddrType_t *dstAddr,
  414. uint8 armMode, uint8 disableDefaultRsp, uint8 seqNum );
  415. /*
  416. * Call to send out a Bypass Command ( IAS ACE Cluster )
  417. * numberOfZones uint8 from 0 to 255
  418. * *bypassBuf - 256 bytes deep buffer TBD / nnl
  419. */
  420. extern ZStatus_t zclSS_Send_IAS_ACE_BypassCmd( uint8 srcEP, afAddrType_t *dstAddr,
  421. uint8 numberOfZones, uint8 *bypassBuf,
  422. uint8 disableDefaultRsp, uint8 seqNum );
  423. /*
  424. * Call to send out a Get Zone Information Command ( IAS ACE Cluster )
  425. * zoneID - 8 bit value from 0 to 255
  426. */
  427. extern ZStatus_t zclSS_Send_IAS_ACE_GetZoneInformationCmd( uint8 srcEP, afAddrType_t *dstAddr,
  428. uint8 zoneID, uint8 disableDefaultRsp, uint8 seqNum );
  429. /*
  430. * Call to send out a ArmResponse Command ( IAS ACE Cluster )
  431. * armNotification - uint8
  432. */
  433. extern ZStatus_t zclSS_Send_IAS_ACE_ArmResponse( uint8 srcEP, afAddrType_t *dstAddr,
  434. uint8 armNotification, uint8 disableDefaultRsp, uint8 seqNum );
  435. /*
  436. * Call to send out a Get Zone ID Map Response Command ( IAS ACE Cluster )
  437. * *zoneIDMap - pointer to an array of 16 uint16s
  438. */
  439. extern ZStatus_t zclSS_Send_IAS_ACE_GetZoneIDMapResponseCmd( uint8 srcEP, afAddrType_t *dstAddr,
  440. uint16 *zoneIDMap, uint8 disableDefaultRsp, uint8 seqNum );
  441. /*
  442. * Call to send out a Get Zone Information Response Command ( IAS ACE Cluster )
  443. * zoneID - 8 bit value from 0 to 255
  444. * zoneType - 16 bit
  445. * *ieeeAddress - pointer to 64 bit address
  446. */
  447. extern ZStatus_t zclSS_Send_IAS_ACE_GetZoneInformationResponseCmd( uint8 srcEP, afAddrType_t *dstAddr,
  448. uint8 zoneID, uint16 zoneType, uint8 *ieeeAddress,
  449. uint8 disableDefaultRsp, uint8 seqNum );
  450. #endif // ZCL_ACE
  451. #ifdef ZCL_WD
  452. /*
  453. * Call to send out a Start Warning Command ( IAS WD Cluster )
  454. * *warning - ptr to bitfields and duration
  455. */
  456. extern ZStatus_t zclSS_Send_IAS_WD_StartWarningCmd( uint8 srcEP, afAddrType_t *dstAddr,
  457. zclCmdSSWDStartWarningPayload_t *warning,
  458. uint8 disableDefaultRsp, uint8 seqNum );
  459. /*
  460. * Call to send out a Squawk Command ( IAS WD Cluster )
  461. * squawk - ptr to bitfields (one byte worth)
  462. */
  463. extern ZStatus_t zclSS_Send_IAS_WD_SquawkCmd( uint8 srcEP, afAddrType_t *dstAddr,
  464. zclCmdSSWDSquawkPayload_t *squawk,
  465. uint8 disableDefaultRsp, uint8 seqNum );
  466. #endif // ZCL_WD
  467. #if defined(ZCL_ZONE) || defined(ZCL_ACE)
  468. /*
  469. * Call to update Zone Address for zoneID
  470. * ieeeAddr - ptr to IEEE address
  471. */
  472. extern void zclSS_UpdateZoneAddress( uint8 endpoint, uint8 zoneID, uint8 *ieeeAddr );
  473. /*
  474. * Call to remove a zone with endpoint and zoneID
  475. * zoneID - zone to be removed
  476. */
  477. extern uint8 zclSS_RemoveZone( uint8 endpoint, uint8 zoneID );
  478. #endif // ZCL_ZONE || ZCL_ACE
  479. /*********************************************************************
  480. *********************************************************************/
  481. #ifdef __cplusplus
  482. }
  483. #endif
  484. #endif /* ZCL_SS_H */