mirror of
https://github.com/stargieg/bacnet-stack
synced 2025-10-26 23:35:52 +08:00
cleanup av object
This commit is contained in:
parent
ecfd811f19
commit
a699d8f43d
|
|
@ -65,22 +65,6 @@ unsigned max_analog_values_int = 0;
|
||||||
ANALOG_VALUE_DESCR AV_Descr[MAX_ANALOG_VALUES];
|
ANALOG_VALUE_DESCR AV_Descr[MAX_ANALOG_VALUES];
|
||||||
|
|
||||||
|
|
||||||
/* value/name tuples */
|
|
||||||
struct inst_tuple {
|
|
||||||
char idx[18];
|
|
||||||
struct inst_tuple *next;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct inst_tuple inst_tuple_t;
|
|
||||||
|
|
||||||
/* structure to hold tuple-list and uci context during iteration */
|
|
||||||
struct inst_itr_ctx {
|
|
||||||
struct inst_tuple *list;
|
|
||||||
struct uci_context *ctx;
|
|
||||||
char *section;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/* These three arrays are used by the ReadPropertyMultiple handler */
|
/* These three arrays are used by the ReadPropertyMultiple handler */
|
||||||
static const int Analog_Value_Properties_Required[] = {
|
static const int Analog_Value_Properties_Required[] = {
|
||||||
PROP_OBJECT_IDENTIFIER,
|
PROP_OBJECT_IDENTIFIER,
|
||||||
|
|
@ -135,9 +119,10 @@ void Analog_Value_Property_Lists(
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
void load_inst(const char *sec_idx, struct inst_itr_ctx *itr)
|
void Analog_Value_Load_UCI_List(const char *sec_idx,
|
||||||
|
struct av_inst_itr_ctx *itr)
|
||||||
{
|
{
|
||||||
inst_tuple_t *t = malloc(sizeof (inst_tuple_t));
|
av_inst_tuple_t *t = malloc(sizeof(av_inst_tuple_t));
|
||||||
bool disable;
|
bool disable;
|
||||||
disable = ucix_get_option_int(itr->ctx, itr->section, sec_idx,
|
disable = ucix_get_option_int(itr->ctx, itr->section, sec_idx,
|
||||||
"disable", 0);
|
"disable", 0);
|
||||||
|
|
@ -145,11 +130,12 @@ void load_inst(const char *sec_idx, struct inst_itr_ctx *itr)
|
||||||
return;
|
return;
|
||||||
if (disable)
|
if (disable)
|
||||||
return;
|
return;
|
||||||
if( (t = (inst_tuple_t *)malloc(sizeof(inst_tuple_t))) != NULL ) {
|
if( (t = (av_inst_tuple_t *)malloc(sizeof(av_inst_tuple_t))) != NULL ) {
|
||||||
strncpy(t->idx, sec_idx, sizeof(t->idx));
|
strncpy(t->idx, sec_idx, sizeof(t->idx));
|
||||||
t->next = itr->list;
|
t->next = itr->list;
|
||||||
itr->list = t;
|
itr->list = t;
|
||||||
}
|
}
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -195,10 +181,8 @@ void Analog_Value_Init(
|
||||||
|
|
||||||
char *section;
|
char *section;
|
||||||
char *type;
|
char *type;
|
||||||
char idx[18];
|
struct av_inst_itr_ctx itr_m;
|
||||||
struct inst_itr_ctx itr_m;
|
|
||||||
section = "bacnet_av";
|
section = "bacnet_av";
|
||||||
inst_tuple_t *cur = malloc(sizeof (inst_tuple_t));
|
|
||||||
|
|
||||||
#if PRINT_ENABLED
|
#if PRINT_ENABLED
|
||||||
fprintf(stderr, "Analog_Value_Init\n");
|
fprintf(stderr, "Analog_Value_Init\n");
|
||||||
|
|
@ -211,12 +195,12 @@ void Analog_Value_Init(
|
||||||
fprintf(stderr, "Failed to load config file bacnet_av\n");
|
fprintf(stderr, "Failed to load config file bacnet_av\n");
|
||||||
#endif
|
#endif
|
||||||
type = "av";
|
type = "av";
|
||||||
inst_tuple_t *cur = malloc(sizeof (inst_tuple_t));
|
av_inst_tuple_t *cur = malloc(sizeof (av_inst_tuple_t));
|
||||||
itr_m.list = NULL;
|
itr_m.list = NULL;
|
||||||
itr_m.section = section;
|
itr_m.section = section;
|
||||||
itr_m.ctx = ctx;
|
itr_m.ctx = ctx;
|
||||||
ucix_for_each_section_type(ctx, section, type,
|
ucix_for_each_section_type(ctx, section, type,
|
||||||
(void *)load_inst, &itr_m);
|
(void *)Analog_Value_Load_UCI_List, &itr_m);
|
||||||
|
|
||||||
ucidescription_default = ucix_get_option(ctx, sec, "default",
|
ucidescription_default = ucix_get_option(ctx, sec, "default",
|
||||||
"description");
|
"description");
|
||||||
|
|
@ -365,7 +349,7 @@ void Analog_Value_Init(
|
||||||
AV_Descr[i].Event_State = EVENT_STATE_NORMAL;
|
AV_Descr[i].Event_State = EVENT_STATE_NORMAL;
|
||||||
/* notification class not connected */
|
/* notification class not connected */
|
||||||
if (ucinc > -1) AV_Descr[i].Notification_Class = ucinc;
|
if (ucinc > -1) AV_Descr[i].Notification_Class = ucinc;
|
||||||
else AV_Descr[i].Notification_Class = BACNET_MAX_INSTANCE;
|
else AV_Descr[i].Notification_Class = 0;
|
||||||
if (ucievent > -1) AV_Descr[i].Event_Enable = ucievent;
|
if (ucievent > -1) AV_Descr[i].Event_Enable = ucievent;
|
||||||
else AV_Descr[i].Event_Enable = 0;
|
else AV_Descr[i].Event_Enable = 0;
|
||||||
if (ucitime_delay > -1) AV_Descr[i].Time_Delay = ucitime_delay;
|
if (ucitime_delay > -1) AV_Descr[i].Time_Delay = ucitime_delay;
|
||||||
|
|
@ -460,7 +444,9 @@ bool Analog_Value_Valid_Instance(
|
||||||
unsigned index = 0; /* offset from instance lookup */
|
unsigned index = 0; /* offset from instance lookup */
|
||||||
index = Analog_Value_Instance_To_Index(object_instance);
|
index = Analog_Value_Instance_To_Index(object_instance);
|
||||||
if (index == MAX_ANALOG_VALUES) {
|
if (index == MAX_ANALOG_VALUES) {
|
||||||
printf("Analog_Value_Valid_Instance %i invalid\n",object_instance);
|
#if PRINT_ENABLED
|
||||||
|
fprintf(stderr, "Analog_Value_Valid_Instance %i invalid\n",object_instance);
|
||||||
|
#endif
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
CurrentAV = &AV_Descr[index];
|
CurrentAV = &AV_Descr[index];
|
||||||
|
|
@ -475,7 +461,7 @@ bool Analog_Value_Change_Of_Value(
|
||||||
{
|
{
|
||||||
ANALOG_VALUE_DESCR *CurrentAV;
|
ANALOG_VALUE_DESCR *CurrentAV;
|
||||||
bool status = false;
|
bool status = false;
|
||||||
unsigned index;
|
unsigned index = 0;
|
||||||
|
|
||||||
if (Analog_Value_Valid_Instance(object_instance)) {
|
if (Analog_Value_Valid_Instance(object_instance)) {
|
||||||
index = Analog_Value_Instance_To_Index(object_instance);
|
index = Analog_Value_Instance_To_Index(object_instance);
|
||||||
|
|
@ -490,7 +476,7 @@ void Analog_Value_Change_Of_Value_Clear(
|
||||||
uint32_t object_instance)
|
uint32_t object_instance)
|
||||||
{
|
{
|
||||||
ANALOG_VALUE_DESCR *CurrentAV;
|
ANALOG_VALUE_DESCR *CurrentAV;
|
||||||
unsigned index;
|
unsigned index = 0;
|
||||||
|
|
||||||
if (Analog_Value_Valid_Instance(object_instance)) {
|
if (Analog_Value_Valid_Instance(object_instance)) {
|
||||||
index = Analog_Value_Instance_To_Index(object_instance);
|
index = Analog_Value_Instance_To_Index(object_instance);
|
||||||
|
|
@ -891,7 +877,7 @@ int Analog_Value_Read_Property(
|
||||||
BACNET_BIT_STRING bit_string;
|
BACNET_BIT_STRING bit_string;
|
||||||
BACNET_CHARACTER_STRING char_string;
|
BACNET_CHARACTER_STRING char_string;
|
||||||
float present_value = 0;
|
float present_value = 0;
|
||||||
unsigned object_index = 0;
|
unsigned index = 0;
|
||||||
unsigned i = 0;
|
unsigned i = 0;
|
||||||
uint8_t *apdu = NULL;
|
uint8_t *apdu = NULL;
|
||||||
|
|
||||||
|
|
@ -902,10 +888,9 @@ int Analog_Value_Read_Property(
|
||||||
|
|
||||||
apdu = rpdata->application_data;
|
apdu = rpdata->application_data;
|
||||||
|
|
||||||
printf(stderr,"Analog_Value_Read_Property %i\n",rpdata->object_instance);
|
|
||||||
if (Analog_Value_Valid_Instance(rpdata->object_instance)) {
|
if (Analog_Value_Valid_Instance(rpdata->object_instance)) {
|
||||||
object_index = Analog_Value_Instance_To_Index(rpdata->object_instance);
|
index = Analog_Value_Instance_To_Index(rpdata->object_instance);
|
||||||
CurrentAV = &AV_Descr[object_index];
|
CurrentAV = &AV_Descr[index];
|
||||||
} else
|
} else
|
||||||
return BACNET_STATUS_ERROR;
|
return BACNET_STATUS_ERROR;
|
||||||
|
|
||||||
|
|
@ -1191,7 +1176,7 @@ bool Analog_Value_Write_Property(
|
||||||
{
|
{
|
||||||
ANALOG_VALUE_DESCR *CurrentAV;
|
ANALOG_VALUE_DESCR *CurrentAV;
|
||||||
bool status = false; /* return value */
|
bool status = false; /* return value */
|
||||||
unsigned int object_index = 0;
|
unsigned index = 0;
|
||||||
int object_type = 0;
|
int object_type = 0;
|
||||||
uint32_t object_instance = 0;
|
uint32_t object_instance = 0;
|
||||||
unsigned int priority = 0;
|
unsigned int priority = 0;
|
||||||
|
|
@ -1227,9 +1212,9 @@ bool Analog_Value_Write_Property(
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (Analog_Value_Valid_Instance(wp_data->object_instance)) {
|
if (Analog_Value_Valid_Instance(wp_data->object_instance)) {
|
||||||
object_index = Analog_Value_Instance_To_Index(wp_data->object_instance);
|
index = Analog_Value_Instance_To_Index(wp_data->object_instance);
|
||||||
CurrentAV = &AV_Descr[object_index];
|
CurrentAV = &AV_Descr[index];
|
||||||
sprintf(idx_cc,"%d",object_index);
|
sprintf(idx_cc,"%d",index);
|
||||||
idx_c = idx_cc;
|
idx_c = idx_cc;
|
||||||
} else
|
} else
|
||||||
return false;
|
return false;
|
||||||
|
|
@ -1537,7 +1522,7 @@ void Analog_Value_Intrinsic_Reporting(
|
||||||
ANALOG_VALUE_DESCR *CurrentAV;
|
ANALOG_VALUE_DESCR *CurrentAV;
|
||||||
BACNET_EVENT_NOTIFICATION_DATA event_data;
|
BACNET_EVENT_NOTIFICATION_DATA event_data;
|
||||||
BACNET_CHARACTER_STRING msgText;
|
BACNET_CHARACTER_STRING msgText;
|
||||||
unsigned int object_index;
|
unsigned index = 0;
|
||||||
uint8_t FromState = 0;
|
uint8_t FromState = 0;
|
||||||
uint8_t ToState;
|
uint8_t ToState;
|
||||||
float ExceededLimit = 0.0f;
|
float ExceededLimit = 0.0f;
|
||||||
|
|
@ -1545,10 +1530,8 @@ void Analog_Value_Intrinsic_Reporting(
|
||||||
bool SendNotify = false;
|
bool SendNotify = false;
|
||||||
|
|
||||||
if (Analog_Value_Valid_Instance(object_instance)) {
|
if (Analog_Value_Valid_Instance(object_instance)) {
|
||||||
object_index = Analog_Value_Instance_To_Index(object_instance);
|
index = Analog_Value_Instance_To_Index(object_instance);
|
||||||
printf(stderr,"Analog_Value_Intrinsic_Reporting %i\n",
|
CurrentAV = &AV_Descr[index];
|
||||||
object_index);
|
|
||||||
CurrentAV = &AV_Descr[object_index];
|
|
||||||
} else
|
} else
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
@ -1909,14 +1892,14 @@ int Analog_Value_Alarm_Ack(
|
||||||
BACNET_ERROR_CODE * error_code)
|
BACNET_ERROR_CODE * error_code)
|
||||||
{
|
{
|
||||||
ANALOG_VALUE_DESCR *CurrentAV;
|
ANALOG_VALUE_DESCR *CurrentAV;
|
||||||
unsigned int object_index;
|
unsigned index = 0;
|
||||||
|
|
||||||
if (Analog_Value_Valid_Instance(alarmack_data->eventObjectIdentifier.
|
if (Analog_Value_Valid_Instance(alarmack_data->eventObjectIdentifier.
|
||||||
instance)) {
|
instance)) {
|
||||||
object_index =
|
index =
|
||||||
Analog_Value_Instance_To_Index(alarmack_data->eventObjectIdentifier.
|
Analog_Value_Instance_To_Index(alarmack_data->eventObjectIdentifier.
|
||||||
instance);
|
instance);
|
||||||
CurrentAV = &AV_Descr[object_index];
|
CurrentAV = &AV_Descr[index];
|
||||||
} else {
|
} else {
|
||||||
*error_code = ERROR_CODE_UNKNOWN_OBJECT;
|
*error_code = ERROR_CODE_UNKNOWN_OBJECT;
|
||||||
return -1;
|
return -1;
|
||||||
|
|
|
||||||
|
|
@ -81,6 +81,25 @@ int max_analog_values;
|
||||||
#endif /* INTRINSIC_REPORTING */
|
#endif /* INTRINSIC_REPORTING */
|
||||||
} ANALOG_VALUE_DESCR;
|
} ANALOG_VALUE_DESCR;
|
||||||
|
|
||||||
|
/* value/name tuples */
|
||||||
|
struct av_inst_tuple {
|
||||||
|
char idx[18];
|
||||||
|
struct av_inst_tuple *next;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct av_inst_tuple av_inst_tuple_t;
|
||||||
|
|
||||||
|
/* structure to hold tuple-list and uci context during iteration */
|
||||||
|
struct av_inst_itr_ctx {
|
||||||
|
struct av_inst_tuple *list;
|
||||||
|
struct uci_context *ctx;
|
||||||
|
char *section;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
void Analog_Value_Load_UCI_List(
|
||||||
|
const char *sec_idx,
|
||||||
|
struct av_inst_itr_ctx *itr);
|
||||||
|
|
||||||
void Analog_Value_Property_Lists(
|
void Analog_Value_Property_Lists(
|
||||||
const int **pRequired,
|
const int **pRequired,
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user