Changed BACnetPropertyStates to support more enumerations. Added apdu size checking on decode. Removed BACnetPropertyStates local enumeration. Increased BACnetPropertyStates codec unit test coverage.

This commit is contained in:
Steve Karg
2024-01-05 16:00:42 -06:00
parent bb081d28da
commit ba4b0ca7c6
6 changed files with 980 additions and 286 deletions
+53 -18
View File
@@ -31,25 +31,8 @@
#include "bacnet/bacapp.h"
#include "bacnet/timestamp.h"
typedef enum {
BOOLEAN_VALUE,
BINARY_VALUE,
EVENT_TYPE,
POLARITY,
PROGRAM_CHANGE,
PROGRAM_STATE,
REASON_FOR_HALT,
RELIABILITY,
STATE,
SYSTEM_STATUS,
UNITS,
UNSIGNED_VALUE,
LIFE_SAFETY_MODE,
LIFE_SAFETY_STATE
} BACNET_PROPERTY_STATE_TYPE;
typedef struct {
BACNET_PROPERTY_STATE_TYPE tag;
BACNET_PROPERTY_STATES tag;
union {
bool booleanValue;
BACNET_BINARY_PV binaryValue;
@@ -65,6 +48,52 @@ typedef struct {
BACNET_UNSIGNED_INTEGER unsignedValue;
BACNET_LIFE_SAFETY_MODE lifeSafetyMode;
BACNET_LIFE_SAFETY_STATE lifeSafetyState;
BACNET_RESTART_REASON restartReason;
BACNET_DOOR_ALARM_STATE doorAlarmState;
BACNET_ACTION action;
BACNET_DOOR_SECURED_STATUS doorSecuredStatus;
BACNET_DOOR_STATUS doorStatus;
BACNET_DOOR_VALUE doorValue;
BACNET_FILE_ACCESS_METHOD fileAccessMethod;
BACNET_LOCK_STATUS lockStatus;
BACNET_LIFE_SAFETY_OPERATION lifeSafetyOperation;
BACNET_MAINTENANCE maintenance;
BACNET_NODE_TYPE nodeType;
BACNET_NOTIFY_TYPE notifyType;
BACNET_SECURITY_LEVEL securityLevel;
BACNET_SHED_STATE shedState;
BACNET_SILENCED_STATE silencedState;
BACNET_ACCESS_EVENT accessEvent;
BACNET_ACCESS_ZONE_OCCUPANCY_STATE zoneOccupancyState;
BACNET_ACCESS_CREDENTIAL_DISABLE_REASON accessCredDisableReason;
BACNET_ACCESS_CREDENTIAL_DISABLE accessCredDisable;
BACNET_AUTHENTICATION_STATUS authenticationStatus;
BACNET_BACKUP_STATE backupState;
BACNET_WRITE_STATUS writeStatus;
BACNET_LIGHTING_IN_PROGRESS lightingInProgress;
BACNET_LIGHTING_OPERATION lightingOperation;
BACNET_LIGHTING_TRANSITION lightingTransition;
int32_t integerValue;
BACNET_BINARY_LIGHTING_PV binaryLightingValue;
BACNET_TIMER_STATE timerState;
BACNET_TIMER_TRANSITION timerTransition;
BACNET_IP_MODE bacnetIPMode;
BACNET_PORT_COMMAND networkPortCommand;
BACNET_PORT_TYPE networkType;
BACNET_PORT_QUALITY networkNumberQuality;
BACNET_ESCALATOR_OPERATION_DIRECTION escalatorOperationDirection;
BACNET_ESCALATOR_FAULT escalatorFault;
BACNET_ESCALATOR_MODE escalatorMode;
BACNET_LIFT_CAR_DIRECTION liftCarDirection;
BACNET_LIFT_CAR_DOOR_COMMAND liftCarDoorCommand;
BACNET_LIFT_CAR_DRIVE_STATUS liftCarDriveStatus;
BACNET_LIFT_CAR_MODE liftCarMode;
BACNET_LIFT_GROUP_MODE liftGroupMode;
BACNET_LIFT_FAULT liftFault;
BACNET_PROTOCOL_LEVEL protocolLevel;
BACNET_AUDIT_LEVEL auditLevel;
BACNET_AUDIT_OPERATION auditOperation;
uint32_t extendedValue;
} state;
} BACNET_PROPERTY_STATE;
@@ -72,6 +101,12 @@ typedef struct {
extern "C" {
#endif /* __cplusplus */
BACNET_STACK_EXPORT
int bacapp_property_state_decode(
uint8_t *apdu,
uint32_t apdu_size,
BACNET_PROPERTY_STATE *value);
BACNET_STACK_EXPORT
int bacapp_decode_property_state(
uint8_t * apdu,