| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775 |
- /**************************************************************************************************
- Filename: zcl_SE.h
- Revised: $Date: 2006-09-08 15:51:21 -0700 (Fri, 08 Sep 2006) $
- Revision: $Revision: 11934 $
- Description: This file contains the ZCL SE (Smart Energy) Profile definitions.
- Copyright 2007-2009 Texas Instruments Incorporated. All rights reserved.
- IMPORTANT: Your use of this Software is limited to those specific rights
- granted under the terms of a software license agreement between the user
- who downloaded the software, his/her employer (which must be your employer)
- and Texas Instruments Incorporated (the "License"). You may not use this
- Software unless you agree to abide by the terms of the License. The License
- limits your use, and you acknowledge, that the Software may not be modified,
- copied or distributed unless embedded on a Texas Instruments microcontroller
- or used solely and exclusively in conjunction with a Texas Instruments radio
- frequency transceiver, which is integrated into your product. Other than for
- the foregoing purpose, you may not use, reproduce, copy, prepare derivative
- works of, modify, distribute, perform, display or sell this Software and/or
- its documentation for any purpose.
- YOU FURTHER ACKNOWLEDGE AND AGREE THAT THE SOFTWARE AND DOCUMENTATION ARE
- PROVIDED “AS IS?WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED,
- INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY, TITLE,
- NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL
- TEXAS INSTRUMENTS OR ITS LICENSORS BE LIABLE OR OBLIGATED UNDER CONTRACT,
- NEGLIGENCE, STRICT LIABILITY, CONTRIBUTION, BREACH OF WARRANTY, OR OTHER
- LEGAL EQUITABLE THEORY ANY DIRECT OR INDIRECT DAMAGES OR EXPENSES
- INCLUDING BUT NOT LIMITED TO ANY INCIDENTAL, SPECIAL, INDIRECT, PUNITIVE
- OR CONSEQUENTIAL DAMAGES, LOST PROFITS OR LOST DATA, COST OF PROCUREMENT
- OF SUBSTITUTE GOODS, TECHNOLOGY, SERVICES, OR ANY CLAIMS BY THIRD PARTIES
- (INCLUDING BUT NOT LIMITED TO ANY DEFENSE THEREOF), OR OTHER SIMILAR COSTS.
- Should you have any questions regarding your right to use this Software,
- contact Texas Instruments Incorporated at www.TI.com.
- **************************************************************************************************/
- #ifndef ZCL_SE_H
- #define ZCL_SE_H
- #ifdef __cplusplus
- extern "C"
- {
- #endif
- /*********************************************************************
- * INCLUDES
- */
- #include "zcl.h"
- /*********************************************************************
- * CONSTANTS
- */
- /********************************************/
- /*** SE Profile Attributes List ************/
- /********************************************/
- // Simple Metering Attribute Set
- #define ATTRID_MASK_SE_READ_INFORMATION_SET 0x0000
- #define ATTRID_MASK_SE_TOU_INFORMATION_SET 0x0100
- #define ATTRID_MASK_SE_METER_STATUS 0x0200
- #define ATTRID_MASK_SE_FORMATTING 0x0300
- #define ATTRID_MASK_SE_ESP_HISTORICAL_CONSUMPTION 0x0400
- #define ATTRID_MASK_SE_LOAD_PROFILE_CONFIGURATION 0x0500
-
- // Simple Metering Cluster - Reading Information Set Attributes 0x00
- #define ATTRID_SE_CURRENT_SUMMATION_DELIVERED ( 0x0000 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_SUMMATION_RECEIVED ( 0x0001 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_MAX_DEMAND_DELIVERED ( 0x0002 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_MAX_DEMAND_RECEIVED ( 0x0003 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_DFT_SUMMATION ( 0x0004 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_DAILY_FREEZE_TIME ( 0x0005 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_POWER_FACTOR ( 0x0006 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_READING_SNAPSHOT_TIME ( 0x0007 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_MAX_DEMAND_DELIVERD_TIME ( 0x0008 | ATTRID_MASK_SE_READ_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_MAX_DEMAND_RECEIVED_TIME ( 0x0009 | ATTRID_MASK_SE_READ_INFORMATION_SET )
-
- // Simple Metering Cluster - TOU Information Set Attributes 0x01
- #define ATTRID_SE_CURRENT_TIER1_SUMMATION_DELIVERED ( 0x0000 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER1_SUMMATION_RECEIVED ( 0x0001 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER2_SUMMATION_DELIVERED ( 0x0002 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER2_SUMMATION_RECEIVED ( 0x0003 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER3_SUMMATION_DELIVERED ( 0x0004 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER3_SUMMATION_RECEIVED ( 0x0005 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER4_SUMMATION_DELIVERED ( 0x0006 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER4_SUMMATION_RECEIVED ( 0x0007 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER5_SUMMATION_DELIVERED ( 0x0008 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER5_SUMMATION_RECEIVED ( 0x0009 | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER6_SUMMATION_DELIVERED ( 0x000A | ATTRID_MASK_SE_TOU_INFORMATION_SET )
- #define ATTRID_SE_CURRENT_TIER6_SUMMATION_RECEIVED ( 0x000B | ATTRID_MASK_SE_TOU_INFORMATION_SET )
-
- // Simple Metering Cluslter - Meter Status Attributes 0x02
- #define ATTRID_SE_STATUS ( 0x0000 | ATTRID_MASK_SE_METER_STATUS )
- // Simple Metering Cluster - Formatting Attributes 0x03
- #define ATTRID_SE_UNIT_OF_MEASURE ( 0x0000 | ATTRID_MASK_SE_FORMATTING )
- #define ATTRID_SE_MULTIPLIER ( 0x0001 | ATTRID_MASK_SE_FORMATTING )
- #define ATTRID_SE_DIVISOR ( 0x0002 | ATTRID_MASK_SE_FORMATTING )
- #define ATTRID_SE_SUMMATION_FORMATTING ( 0x0003 | ATTRID_MASK_SE_FORMATTING )
- #define ATTRID_SE_DEMAND_FORMATTING ( 0x0004 | ATTRID_MASK_SE_FORMATTING )
- #define ATTRID_SE_HISTORICAL_CONSUMPTION_FORMATTING ( 0x0005 | ATTRID_MASK_SE_FORMATTING )
- #define ATTRID_SE_METERING_DEVICE_TYPE ( 0x0006 | ATTRID_MASK_SE_FORMATTING )
- // Simple Metering Cluster - ESP Historical Comsumption Attributes 0x04
- #define ATTRID_SE_INSTANTANEOUS_DEMAND ( 0x0000 | ATTRID_MASK_SE_ESP_HISTORICAL_CONSUMPTION )
- #define ATTRID_SE_CURRENTDAY_CONSUMPTION_DELIVERED ( 0x0001 | ATTRID_MASK_SE_ESP_HISTORICAL_CONSUMPTION )
- #define ATTRID_SE_CURRENTDAY_CONSUMPTION_RECEIVED ( 0x0002 | ATTRID_MASK_SE_ESP_HISTORICAL_CONSUMPTION )
- #define ATTRID_SE_PREVIOUSDAY_CONSUMPTION_DELIVERED ( 0x0003 | ATTRID_MASK_SE_ESP_HISTORICAL_CONSUMPTION )
- #define ATTRID_SE_PREVIOUSDAY_CONSUMPTION_RECEIVED ( 0x0004 | ATTRID_MASK_SE_ESP_HISTORICAL_CONSUMPTION )
- #define ATTRID_SE_CURRENT_PARTIAL_PROFILE_INTERVAL_START_TIME ( 0x0005 | ATTRID_MASK_SE_ESP_HISTORICAL_CONSUMPTION )
- #define ATTRID_SE_CURRENT_PARTIAL_PROFILE_INTERVAL_VALUE ( 0x0006 | ATTRID_MASK_SE_ESP_HISTORICAL_CONSUMPTION )
- // Simple Metering Cluster - Load Profile Configuration Attributes 0x05
- #define ATTRID_SE_MAX_NUMBER_OF_PERIODS_DELIVERED ( 0x0000 | ATTRID_MASK_SE_LOAD_PROFILE_CONFIGURATION )
-
- // Demand Response Client Cluster Attributes
- #define ATTRID_SE_UTILITY_DEFINED_GROUP 0x0000
- #define ATTRID_SE_START_RANDOMIZE_MINUTES 0x0001
- #define ATTRID_SE_STOP_RANDOMIZE_MINUTES 0x0002
-
- /************************************************************/
- /*** SE Profile Command ID ***/
- /************************************************************/
- // Simple Metering Cluster
- #define COMMAND_SE_GET_PROFILE_CMD 0x0000
- #define COMMAND_SE_GET_PROFILE_RSP 0x0000
- #define COMMAND_SE_REQ_MIRROR_CMD 0x0001
- #define COMMAND_SE_REQ_MIRROR_RSP 0x0001
- #define COMMAND_SE_MIRROR_REM_CMD 0x0002
- #define COMMAND_SE_MIRROR_REM_RSP 0x0002
-
- // Pricing Cluster
- #define COMMAND_SE_GET_CURRENT_PRICE 0x0000
- #define COMMAND_SE_GET_SCHEDULED_PRICE 0x0001
- #define COMMAND_SE_PUBLISH_PRICE 0x0000
-
- // Messaging Cluster
- #define COMMAND_SE_DISPLAY_MESSAGE 0x0000
- #define COMMAND_SE_CANCEL_MESSAGE 0x0001
- #define COMMAND_SE_GET_LAST_MESSAGE 0x0000
- #define COMMAND_SE_MESSAGE_CONFIRMATION 0x0001
-
- // Demand Response and Load Control Cluster
- #define COMMAND_SE_LOAD_CONTROL_EVENT 0x0000
- #define COMMAND_SE_CANCEL_LOAD_CONTROL_EVENT 0x0001
- #define COMMAND_SE_CANCEL_ALL_LOAD_CONTROL_EVENT 0x0002
- #define COMMAND_SE_REPORT_EVENT_STATUS 0x0000
- #define COMMAND_SE_GET_SCHEDULED_EVENT 0x0001
- /******************************************************************/
- /*** Other Constants ***/
- /******************************************************************/
-
- // Profile Interval Period Time Frame
- #define PROFILE_INTERVAL_PERIOD_DAILY 0
- #define PROFILE_INTERVAL_PERIOD_60MIN 1
- #define PROFILE_INTERVAL_PERIOD_30MIN 2
- #define PROFILE_INTERVAL_PERIOD_15MIN 3
- #define PROFILE_INTERVAL_PERIOD_10MIN 4
- #define PROFILE_INTERVAL_PERIOD_450SEC 5
- #define PROFILE_INTERVAL_PERIOD_300SEC 6
- #define PROFILE_INTERVAL_PERIOD_150SEC 7
-
- // Profile Interval Status
- #define PROFILE_INTERVAL_STAT_SUCCESS 0x00
- #define PROFILE_INTERVAL_STAT_UNDEFINED_CHANNEL 0x01
- #define PROFILE_INTERVAL_STAT_CHANNEL_NOT_SUPPORT 0x02
- #define PROFILE_INTERVAL_STAT_INVALID_END_TIME 0x03
- #define PROFILE_INTERVAL_STAT_TOO_MANY_PERIOD 0x04
- #define PROFILE_INTERVAL_STAT_NO_INTERVALS 0x05
- // Command Packet Length
- #define PACKET_LEN_SE_PUBLISH_PRICE 34
- #define PACKET_LEN_SE_LOAD_CONTROL_EVENT 23
- #define PACKET_LEN_SE_GET_SCHEDULED_EVENT 5
- #define PACKET_LEN_SE_CANCEL_LOAD_CONTROL_EVENT 12
- #define PACKET_LEN_SE_REPORT_EVENT_STATUS_ONLY 18
- #define PACKET_LEN_SE_REPORT_EVENT_STATUS (PACKET_LEN_SE_REPORT_EVENT_STATUS_ONLY + SE_PROFILE_SIGNATURE_LENGTH)
- // Maximum value for Command Fields Range Checking
- #define MAX_DURATION_IN_MINUTES_SE_LOAD_CONTROL 1440 // One day
- #define MAX_CRITICAL_LEVEL_SE_LOAD_CONTROL 0x0F
- #define MAX_TEMPERATURE_SETPOINT_SE_LOAD_CONTROL 0x7FFF
- #define MIN_AVERAGE_LOAD_ADJUSTMENT_PERCENTAGE_SE -100
- #define MAX_AVERAGE_LOAD_ADJUSTMENT_PERCENTAGE_SE 100
- #define MAX_DUTY_CYCLE_SE_LOAD_CONTROL 100
- #define MAX_INTERVAL_CHANNEL_SE_SIMPLE_METERING 1
- #define MAX_PROFILE_INTERVAL_PERIOD_SE_SIMPLE_METERING 7
- #define MAX_UNIT_OF_MEASURE_SE 7
-
- // Device Class Field Bitmap
- #define SE_DEVICE_CLASS_HVAC_COMPRESSOR_FURNACE 0x0001
- #define SE_DEVICE_CLASS_STRIP_HEATER 0x0002
- #define SE_DEVICE_CLASS_WATER_HEATER 0x0004
- #define SE_DEVICE_CLASS_POOL_PUMP 0x0008
- #define SE_DEVICE_CLASS_SMART_APPLIANCES 0x0010
- #define SE_DEVICE_CLASS_IRRIGATION_PUMP 0x0020
- #define SE_DEVICE_CLASS_MANAGED_CI_LOADS 0x0040
- #define SE_DEVICE_CLASS_SIMPLE_MISC_LOADS 0x0080
- #define SE_DEVICE_CLASS_EXTERIOR_LIGHTING 0x0100
- #define SE_DEVICE_CLASS_INTERIOR_LIGHTING 0x0200
- #define SE_DEVICE_CLASS_ELECTRIC_VEHICLE 0x0400
- #define SE_DEVICE_CLASS_GENERATION_SYSTEMS 0x0800
- // Criticality Levels
- #define SE_CRITICALITY_LEVELS_GREEN 0x01
- #define SE_CRITICALITY_LEVELS_1 0x02
- #define SE_CRITICALITY_LEVELS_2 0x03
- #define SE_CRITICALITY_LEVELS_3 0x04
- #define SE_CRITICALITY_LEVELS_4 0x05
- #define SE_CRITICALITY_LEVELS_5 0x06
- #define SE_CRITICALITY_LEVELS_EMERGENCY 0x07
- #define SE_CRITICALITY_LEVELS_PLANNED_OUTAGE 0x08
- #define SE_CRITICALITY_LEVELS_SERVICE_DISCONNECT 0x09
-
- // Event Control Field Bitmap
- #define SE_EVENT_CONTROL_FIELD_START_TIME 0x01
- #define SE_EVENT_CONTROL_FIELD_END_TIME 0x02
-
- // Optional Fields Value
- #define SE_OPTIONAL_FIELD_UINT8 0xFF
- #define SE_OPTIONAL_FIELD_UINT16 0xFFFF
- #define SE_OPTIONAL_FIELD_UINT32 0xFFFFFFFF
- #define SE_OPTIONAL_FIELD_TEMPERATURE_SET_POINT 0x8000
- #define SE_OPTIONAL_FIELD_INT8 -128
-
- // Event Status Field Values
- #define EVENT_STATUS_LOAD_CONTROL_EVENT_RECEIVED 0x01
- #define EVENT_STATUS_LOAD_CONTROL_EVENT_STARTED 0x02
- #define EVENT_STATUS_LOAD_CONTROL_EVENT_COMPLETED 0x03
- #define EVENT_STATUS_LOAD_CONTROL_USER_OPT_OUT 0x04
- #define EVENT_STATUS_LOAD_CONTROL_USER_OPT_IN 0x05
- #define EVENT_STATUS_LOAD_CONTROL_EVENT_CANCELLED 0x06
- #define EVENT_STATUS_LOAD_CONTROL_EVENT_SUPERSEDED 0x07
- #define EVENT_STATUS_LOAD_CONTROL_REJECTED_DUPLICATEID 0xFA
- #define EVENT_STATUS_LOAD_CONTROL_REJECTED_EVT_EXPIRED 0xFB
- #define EVENT_STATUS_LOAD_CONTROL_REJECTED_EVT_COMPLETED 0xFC
- #define EVENT_STATUS_LOAD_CONTROL_REJECTED_UNDEFINED_EVT 0xFD
- #define EVENT_STATUS_LOAD_CONTROL_EVENT_REJECTED 0xFE
- // Signature type
- #define SE_PROFILE_SIGNATURE_TYPE_ECDSA 0x01
- // Other constants
- #define SE_PROFILE_SIGNATURE_LENGTH 42
- #define SE_PROFILE_MSGCTRL_IMPORTANCE 2
- #define SE_PROFILE_MSGCTRL_CONFREQUIRED 7
-
- /********************************************************************
- * MACROS
- */
-
- /*********************************************************************
- * TYPEDEFS
- */
-
-
- /*** Structures used for callback functions ***/
- typedef struct
- {
- uint8 channel;
- uint32 endTime;
- uint8 numOfPeriods;
- } zclCCGetProfileCmd_t;
- typedef struct
- {
- uint32 endTime;
- uint8 status;
- uint8 profileIntervalPeriod;
- uint8 numOfPeriodDelivered;
- uint24 *intervals;
- } zclCCGetProfileRsp_t;
- typedef struct
- {
- uint16 endpointId ;
- } zclCCReqMirrorRsp_t ;
- typedef struct
- {
- uint16 endpointId ;
- } zclCCMirrorRemRsp_t ;
- typedef struct
- {
- uint8 option;
- } zclCCGetCurrentPrice_t;
- typedef struct
- {
- uint32 startTime;
- uint8 numEvents;
- } zclCCGetScheduledPrice_t;
- typedef struct
- {
- uint32 providerId;
- UTF8String_t rateLabel;
- uint32 issuerEventId;
- uint32 currentTime;
- uint8 unitOfMeasure;
- uint16 currency;
- uint8 priceTralingDigit;
- uint32 startTime;
- uint16 durationInMinutes;
- uint32 price;
- uint8 priceRatio;
- uint32 generationPrice;
- uint8 generationPriceRatio;
- uint8 priceTier;
- } zclCCPublishPrice_t;
- typedef struct
- {
- uint8 transmissionMode; // valid value 0~2
- uint8 importance; // 0~3
- uint8 confirmationRequired; // 0~1
- } zclMessageCtrl_t;
- typedef struct
- {
- uint32 messageId;
- zclMessageCtrl_t messageCtrl;
- uint32 startTime;
- uint16 durationInMinutes;
- UTF8String_t msgString;
- } zclCCDisplayMessage_t;
- typedef struct
- {
- uint32 messageId;
- zclMessageCtrl_t messageCtrl;
- } zclCCCancelMessage_t;
- typedef struct
- {
- uint32 messageId;
- uint32 confirmTime;
- } zclCCMessageConfirmation_t;
- typedef struct
- {
- uint32 issuerEvent;
- uint24 deviceGroupClass;
- uint32 startTime;
- uint16 durationInMinutes;
- uint8 criticalityLevel;
- uint8 coolingTemperatureOffset;
- uint8 heatingTemperatureOffset;
- uint16 coolingTemperatureSetPoint;
- uint16 heatingTemperatureSetPoint;
- int8 averageLoadAdjustmentPercentage;
- uint8 dutyCycle;
- uint8 eventControl;
- } zclCCLoadControlEvent_t;
- typedef struct
- {
- uint32 issuerEventID;
- uint24 deviceGroupClass;
- uint8 cancelControl;
- uint32 effectiveTime;
- } zclCCCancelLoadControlEvent_t;
- typedef struct
- {
- uint8 cancelControl;
- } zclCCCancelAllLoadControlEvents_t;
- typedef struct
- {
- uint32 issuerEventID;
- uint32 eventStartTime;
- uint8 eventStatus;
- uint8 criticalityLevelApplied;
- uint16 coolingTemperatureSetPointApplied;
- uint16 heatingTemperatureSetPointApplied;
- int8 averageLoadAdjustment;
- uint8 dutyCycleApplied;
- uint8 eventControl;
- uint8 signatureType;
- uint8 signature[SE_PROFILE_SIGNATURE_LENGTH];
- } zclCCReportEventStatus_t;
- typedef struct
- {
- uint32 startTime;
- uint8 numEvents;
- } zclCCGetScheduledEvent_t;
- typedef enum
- {
- zclSE_SimpleMeter_GetProfileRsp_Status_Success = 0,
- zclSE_SimpleMeter_GetProfileRsp_Status_UndefinedInterval,
- zclSE_SimpleMeter_GetProfileRsp_Status_IntervalNotSupport,
- zclSE_SimpleMeter_GetProfileRsp_Status_InvalidEndTime,
- zclSE_SimpleMeter_GetProfileRsp_Status_MorePeriodRequested,
- zclSE_SimpleMeter_GetProfileRsp_Status_NotAvailable
- }zclSE_SimpleMeter_GetProfileRsp_Status;
- // This callback is called to process an incoming Get Profile
- // command. On receipt of this command, the device responds with
- // Get Profile Response.
- typedef void (*zclSE_SimpleMeter_GetProfileCmd_t)( zclCCGetProfileCmd_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Get Profile
- // Response.
- typedef void (*zclSE_SimpleMeter_GetProfileRsp_t)( zclCCGetProfileRsp_t *pRsp, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Request Mirror
- // command. In receipt of this command, the device finds a mirroring
- // endpoint and responds with a Request Mirror Response
- typedef void (*zclSE_SimpleMeter_ReqMirrorCmd_t)( afAddrType_t *srcAddr, uint8 seqNum ) ;
- // This callback is called to process an incoming Request Mirror Response
- typedef void (*zclSE_SimpleMeter_ReqMirrorRsp_t)( zclCCReqMirrorRsp_t *pRsp, afAddrType_t *srcAddr, uint8 seqNum ) ;
- // This callback is called to process an incoming Mirror Removed
- // command. In receipt of this command, the device removes the
- // mirrored data from the metering device and responds with a
- // Mirror Removed response.
- typedef void (*zclSE_SimpleMeter_MirrorRemCmd_t)( afAddrType_t *srcAddr, uint8 seqNum ) ;
- // This callback is called to process an incoming Mirror Remove Response
- typedef void (*zclSE_SimpleMeter_MirrorRemRsp_t)( zclCCMirrorRemRsp_t *pRsp, afAddrType_t *srcAddr, uint8 seqNum ) ;
- // This callback is called to process an incoming Get Current Price
- // command. On receipt of this command, the device responds with
- // Publish Price.
- typedef void (*zclSE_Pricing_GetCurentPrice_t)( zclCCGetCurrentPrice_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Get Scheduled Price
- // command. On receipt of this command, the device responds with
- // Publish Price.
- typedef void (*zclSE_Pricing_GetScheduledPrice_t)( zclCCGetScheduledPrice_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Get Scheduled Price
- // command. On receipt of this command, the device responds with
- // Publish Price.
- typedef void (*zclSE_Pricing_PublishPrice_t)( zclCCPublishPrice_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Display Message
- // command.
- typedef void (*zclSE_Message_DisplayMessage_t)( zclCCDisplayMessage_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Cancel Message
- // command.
- typedef void (*zclSE_Message_CancelMessage_t)( zclCCCancelMessage_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Get Last Message
- // command. On receipt of this command, the device responds with
- // Display Message.
- typedef void (*zclSE_Message_GetLastMessage_t)( afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Message Confirmation
- // command.
- typedef void (*zclSE_Message_MessageConfirmation_t)( zclCCMessageConfirmation_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Load Control Event Command
- // command.
- typedef void (*zclSE_LoadControl_LoadControlEvent_t)( zclCCLoadControlEvent_t *pCmd, afAddrType_t *srcAddr, uint8 status, uint8 seqNum );
- // This callback is called to process an incoming Cancel Load Control Event Command
- // command.
- typedef void (*zclSE_LoadControl_CancelLoadControlEvent_t)( zclCCCancelLoadControlEvent_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum);
- // This callback is called to process an incoming Cancel All Load Control Event Command
- // command.
- typedef void (*zclSE_LoadControl_CancelAllLoadControlEvents_t)( zclCCCancelAllLoadControlEvents_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum );
- // This callback is called to process an incoming Report Event Status Command
- // command.
- typedef void (*zclSE_LoadControl_ReportEventStatus_t)( zclCCReportEventStatus_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum);
- // This callback is called to process an incoming Get Scheduled Event Command
- // command.
- typedef void (*zclSE_LoadControl_GetScheduledEvent_t)( zclCCGetScheduledEvent_t *pCmd, afAddrType_t *srcAddr, uint8 seqNum);
- // Register Callbacks table entry - enter function pointers for callbacks that
- // the application would like to receive
- typedef struct
- {
- zclSE_SimpleMeter_GetProfileCmd_t pfnSimpleMeter_GetProfileCmd;
- zclSE_SimpleMeter_GetProfileRsp_t pfnSimpleMeter_GetProfileRsp;
- zclSE_SimpleMeter_ReqMirrorCmd_t pfnSimpleMeter_ReqMirrorCmd;
- zclSE_SimpleMeter_ReqMirrorRsp_t pfnSimpleMeter_ReqMirrorRsp;
- zclSE_SimpleMeter_MirrorRemCmd_t pfnSimpleMeter_MirrorRemCmd;
- zclSE_SimpleMeter_MirrorRemRsp_t pfnSimpleMeter_MirrorRemRsp;
- zclSE_Pricing_GetCurentPrice_t pfnPricing_GetCurrentPrice;
- zclSE_Pricing_GetScheduledPrice_t pfnPricing_GetScheduledPrice;
- zclSE_Pricing_PublishPrice_t pfnPricing_PublishPrice;
- zclSE_Message_DisplayMessage_t pfnMessage_DisplayMessage;
- zclSE_Message_CancelMessage_t pfnMessage_CancelMessage;
- zclSE_Message_GetLastMessage_t pfnMessage_GetLastMessage;
- zclSE_Message_MessageConfirmation_t pfnMessage_MessageConfirmation;
- zclSE_LoadControl_LoadControlEvent_t pfnLoadControl_LoadControlEvent;
- zclSE_LoadControl_CancelLoadControlEvent_t pfnLoadControl_CancelLoadControlEvent;
- zclSE_LoadControl_CancelAllLoadControlEvents_t pfnLoadControl_CancelAllLoadControlEvents;
- zclSE_LoadControl_ReportEventStatus_t pfnLoadControl_ReportEventStatus;
- zclSE_LoadControl_GetScheduledEvent_t pfnLoadControl_GetScheduledEvents;
- } zclSE_AppCallbacks_t;
- /*********************************************************************
- * VARIABLES
- */
- /*********************************************************************
- * FUNCTIONS
- */
- /*
- * Register for callbacks from this cluster library
- */
- extern ZStatus_t zclSE_RegisterCmdCallbacks( uint8 endpoint, zclSE_AppCallbacks_t *callbacks );
- #ifdef ZCL_SIMPLE_METERING
- /*
- * Send Get Profile Command
- */
- extern ZStatus_t zclSE_SimpleMetering_Send_GetProfileCmd( uint8 srcEP, afAddrType_t *dstAddr,
- uint8 channel, uint32 endTime, uint8 numOfPeriods,
- uint8 disableDefaultRsp, uint8 seqNum );
- /*
- * Send Get Profile Response
- */
- extern ZStatus_t zclSE_SimpleMetering_Send_GetProfileRsp( uint8 srcEP, afAddrType_t *dstAddr,
- uint32 endTime, uint8 rspStatus, uint8 profileIntervalPeriod,
- uint8 numOfPeriodDelivered, uint24 *intervals,
- uint8 disableDefaultRsp, uint8 seqNum );
- /*
- * Send Request Mirror Response
- */
- extern ZStatus_t zclSE_SimpleMetering_Send_ReqMirrorRsp( uint8 srcEP, afAddrType_t *dstAddr,
- uint16 endpointId,
- uint8 disableDefaultRsp, uint8 seqNum ) ;
- /*
- * Send Remove Mirror Response
- */
- extern ZStatus_t zclSE_SimpleMetering_Send_RemMirrorRsp( uint8 srcEP, afAddrType_t *dstAddr,
- uint16 endpointId,
- uint8 disableDefaultRsp, uint8 seqNum ) ;
- #endif
- #ifdef ZCL_PRICING
- /*
- * Send Publish Price Command
- */
- extern ZStatus_t zclSE_Pricing_Send_PublishPrice( uint8 srcEP, afAddrType_t *dstAddr,
- zclCCPublishPrice_t *cmd,
- uint8 disableDefaultRsp, uint8 seqNum );
- extern ZStatus_t zclSE_Pricing_Send_GetScheduledPrice( uint8 srcEP, afAddrType_t *dstAddr,
- zclCCGetScheduledPrice_t *cmd,
- uint8 disableDefaultRsp, uint8 seqNum );
- #endif
- #ifdef ZCL_MESSAGE
- /*
- * Send Display Message Command
- */
- extern ZStatus_t zclSE_Message_Send_DisplayMessage( uint8 srcEP, afAddrType_t *dstAddr,
- zclCCDisplayMessage_t *cmd,
- uint8 disableDefaultRsp, uint8 seqNum );
- /*
- * Send Cancel Message Command
- */
- extern ZStatus_t zclSE_Message_Send_CancelMessage( uint8 srcEP, afAddrType_t *dstAddr,
- uint32 msgId, uint8 msgCtrl,
- uint8 disableDefaultRsp, uint8 seqNum );
- /*
- * Send Message Confirmation
- */
- extern ZStatus_t zclSE_Message_Send_MessageConfirmation( uint8 srcEP, afAddrType_t *dstAddr,
- uint32 msgId, uint32 confirmTime,
- uint8 disableDefaultRsp, uint8 seqNum );
- #endif
- #ifdef ZCL_LOAD_CONTROL
- /*
- * Send Load Control Event
- */
- extern ZStatus_t zclSE_LoadControl_Send_LoadControlEvent( uint8 srcEP, afAddrType_t *dstAddr,
- zclCCLoadControlEvent_t* cmd,
- uint8 disableDefaultRsp, uint8 seqNum );
- /*
- * Send Cancel Load Control Event
- */
- extern ZStatus_t zclSE_LoadControl_Send_CancelLoadControlEvent( uint8 srcEP, afAddrType_t *dstAddr,
- zclCCCancelLoadControlEvent_t *cmd,
- uint8 disableDefaultRsp, uint8 seqNum );
- /*
- * Send Report Event Status
- */
- extern ZStatus_t zclSE_LoadControl_Send_ReportEventStatus( uint8 srcEP, afAddrType_t *dstAddr,
- zclCCReportEventStatus_t* cmd,
- uint8 disableDefaultRsp, uint8 seqNum );
- /*
- * Send Get Scheduled Event
- */
- extern ZStatus_t zclSE_LoadControl_Send_GetScheduledEvent( uint8 srcEP, afAddrType_t *dstAddr,
- zclCCGetScheduledEvent_t *cmd,
- uint8 disableDefaultRsp, uint8 seqNum );
- #endif
- #ifdef ZCL_PRICING
- /*
- * Parse received Publish Price Command
- */
- extern ZStatus_t zclSE_ParseInCmd_PublishPrice( zclCCPublishPrice_t *cmd, uint8 *buf, uint8 len );
- #endif
- #ifdef ZCL_MESSAGE
- /*
- * Parse received Display Message Command
- */
- extern ZStatus_t zclSE_ParseInCmd_DisplayMessage( zclCCDisplayMessage_t *cmd, uint8 *buf, uint8 len );
- #endif
- #ifdef ZCL_LOAD_CONTROL
- /*
- * Parse received Load Control Event
- */
- extern void zclSE_ParseInCmd_LoadControlEvent( zclCCLoadControlEvent_t *cmd, uint8 *buf, uint8 len );
- /*
- * Parse received Cancel Load Control Event
- */
- extern void zclSE_ParseInCmd_CancelLoadControlEvent( zclCCCancelLoadControlEvent_t *cmd, uint8 *buf, uint8 len );
- /*
- * Parse received Report Event Status
- */
- extern void zclSE_ParseInCmd_ReportEventStatus( zclCCReportEventStatus_t *cmd, uint8 *buf, uint8 len );
- #endif
- /*********************************************************************
- * FUNCTION MACROS
- */
- #ifdef ZCL_PRICING
- /*********************************************************************
- * Call to send out a Get Current Price Command
- *
- * Use as
- * ZStatus_t zclSE_Pricing_Send_GetCurrentPrice( uint8 srcEP, afAddrType_t *dstAddr,
- * uint8 option,
- * uint8 disableDefaultRsp, uint8 seqNum )
- *
- * @param srcEP - Sending application's endpoint
- * @param dstAddr - where you want the message to go
- * @param option - Command option field
- * @param disableDefaultRsp - disable default response
- * @param seqNum - ZCL sequence number
- *
- * @return ZStatus_t
- */
- #define zclSE_Pricing_Send_GetCurrentPrice(a, b, c, d, e) \
- zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SE_PRICING, \
- COMMAND_SE_GET_CURRENT_PRICE, TRUE, \
- ZCL_FRAME_CLIENT_SERVER_DIR, (d), 0, (e), 1, &(c) );
- #endif // ZCL_PRICING
- #ifdef ZCL_SIMPLE_METERING
- /*********************************************************************
- * @fn zclSE_SimpleMetering_Send_ReqMirrorCmd
- *
- * @brief Call to send out a Request Mirror Command
- *
- * @param srcEP - Sending application's endpoint
- * @param dstAddr - where you want the message to go
- * @param disableDefaultRsp - disable default response
- * @param seqNum - ZCL sequence number
- *
- * @return ZStatus_t
- */
- #define zclSE_SimpleMetering_Send_ReqMirrorCmd(a, b, c, d) \
- zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SE_SIMPLE_METERING, \
- COMMAND_SE_REQ_MIRROR_CMD, TRUE, \
- ZCL_FRAME_SERVER_CLIENT_DIR, (c), 0, (d), 0, NULL );
- /*********************************************************************
- * @fn zclSE_SimpleMetering_Send_RemMirrorCmd
- *
- * @brief Call to send out a Remove Mirror Command
- *
- * @param srcEP - Sending application's endpoint
- * @param dstAddr - where you want the message to go
- * @param disableDefaultRsp - disable default response
- * @param seqNum - ZCL sequence number
- *
- * @return ZStatus_t
- */
- #define zclSE_SimpleMetering_Send_RemMirrorCmd(a, b, c, d) \
- zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SE_SIMPLE_METERING, \
- COMMAND_SE_MIRROR_REM_CMD, TRUE, \
- ZCL_FRAME_SERVER_CLIENT_DIR, (c), 0, (d), 0, NULL );
- #endif // ZCL_SIMPLE_METERING
- #ifdef ZCL_MESSAGE
- /*********************************************************************
- * Call to send out a Get Last Message
- *
- * Use as
- * ZStatus_t zclSE_Message_Send_GetLastMessage( uint8 srcEP, afAddrType_t *dstAddr,
- * uint8 disableDefaultRsp, uint8 seqNum )
- *
- * @param srcEP - Sending application's endpoint
- * @param dstAddr - where you want the message to go
- * @param disableDefaultRsp - disable default response
- * @param seqNum - ZCL sequence number
- *
- * @return ZStatus_t
- */
- #define zclSE_Message_Send_GetLastMessage(a, b, c, d) \
- zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SE_MESSAGE, \
- COMMAND_SE_GET_LAST_MESSAGE, TRUE, \
- ZCL_FRAME_CLIENT_SERVER_DIR, (c), 0, (d), 0, NULL );
- #endif // ZCL_MESSAGE
- #ifdef ZCL_LOAD_CONTROL
- /*********************************************************************
- * Call to send out a Cancel All Load Control Event
- *
- * Use as
- * ZStatus_t zclSE_LoadControl_Send_CancelAllLoadControlEvent( uint8 srcEP, afAddrType_t *dstAddr,
- * uint8 cancelControl,
- * uint8 disableDefaultRsp, uint8 seqNum )
- *
- * @param srcEP - Sending application's endpoint
- * @param dstAddr - where you want the message to go
- * @param cancelControl
- * @param disableDefaultRsp - disable default response
- * @param seqNum - ZCL sequence number
- *
- * @return ZStatus_t
- */
- #define zclSE_LoadControl_Send_CancelAllLoadControlEvent(a, b, c, d, e) \
- zcl_SendCommand( (a), (b), ZCL_CLUSTER_ID_SE_LOAD_CONTROL, \
- COMMAND_SE_CANCEL_ALL_LOAD_CONTROL_EVENT, TRUE, \
- ZCL_FRAME_SERVER_CLIENT_DIR, (d), 0, (e), 1, &(c) );
- #endif // ZCL_LOAD_CONTROL
- #ifdef __cplusplus
- }
- #endif
- #endif /* ZCL_SE_H */
|