Added dynamic and static RAM file systems to use with file objects. (#1058)
* Added dynamic RAM file system to use with basic bacnet file object. * Added static RAM file system to use with basic bacnet file object. * Added check for read-only during AtomicWriteFile service API for BACnet File object. * Change stm32f4xx example to use static RAM file system. * Fixed bacfile_count() function return type
This commit is contained in:
@@ -166,6 +166,7 @@ set(BACNET_PROJECT_SOURCE
|
||||
${LIBRARY_BACNET_BASIC}/object/ms-input.c
|
||||
${LIBRARY_BACNET_BASIC}/object/mso.c
|
||||
${LIBRARY_BACNET_BASIC}/object/msv.c
|
||||
${LIBRARY_BACNET_BASIC}/object/bacfile.c
|
||||
${LIBRARY_BACNET_BASIC}/object/program.c
|
||||
${LIBRARY_BACNET_BASIC}/program/ubasic/ubasic.c
|
||||
${LIBRARY_BACNET_BASIC}/program/ubasic/tokenizer.c
|
||||
@@ -183,7 +184,9 @@ set(BACNET_PROJECT_SOURCE
|
||||
${LIBRARY_BACNET_BASIC}/service/h_noserv.c
|
||||
${LIBRARY_BACNET_BASIC}/service/s_iam.c
|
||||
${LIBRARY_BACNET_BASIC}/service/s_ihave.c
|
||||
${LIBRARY_BACNET_BASIC}/service/h_arf.c
|
||||
${LIBRARY_BACNET_BASIC}/tsm/tsm.c
|
||||
${LIBRARY_BACNET_BASIC}/sys/bsramfs.c
|
||||
${LIBRARY_BACNET_BASIC}/sys/debug.c
|
||||
${LIBRARY_BACNET_BASIC}/sys/datetime_mstimer.c
|
||||
${LIBRARY_BACNET_BASIC}/sys/days.c
|
||||
@@ -194,6 +197,7 @@ set(BACNET_PROJECT_SOURCE
|
||||
${LIBRARY_BACNET_BASIC}/sys/mstimer.c
|
||||
|
||||
${LIBRARY_BACNET_CORE}/abort.c
|
||||
${LIBRARY_BACNET_CORE}/arf.c
|
||||
${LIBRARY_BACNET_CORE}/bacaction.c
|
||||
${LIBRARY_BACNET_CORE}/bacaddr.c
|
||||
${LIBRARY_BACNET_CORE}/bacapp.c
|
||||
@@ -252,6 +256,7 @@ target_compile_definitions(${EXECUTABLE} PRIVATE
|
||||
-DMAX_APDU=480
|
||||
-DBIG_ENDIAN=0
|
||||
-DMAX_TSM_TRANSACTIONS=1
|
||||
-DBACFILE
|
||||
-DBACAPP_MINIMAL
|
||||
)
|
||||
|
||||
|
||||
@@ -45,10 +45,12 @@ BASIC_SRC = \
|
||||
$(BACNET_BASIC)/object/ms-input.c \
|
||||
$(BACNET_BASIC)/object/mso.c \
|
||||
$(BACNET_BASIC)/object/msv.c \
|
||||
$(BACNET_BASIC)/object/bacfile.c \
|
||||
$(BACNET_BASIC)/object/program.c \
|
||||
$(BACNET_BASIC)/program/ubasic/ubasic.c \
|
||||
$(BACNET_BASIC)/program/ubasic/tokenizer.c \
|
||||
$(BACNET_BASIC)/service/h_apdu.c \
|
||||
$(BACNET_BASIC)/service/h_arf.c \
|
||||
$(BACNET_BASIC)/service/h_dcc.c \
|
||||
$(BACNET_BASIC)/service/h_rd.c \
|
||||
$(BACNET_BASIC)/service/h_rp.c \
|
||||
@@ -60,6 +62,7 @@ BASIC_SRC = \
|
||||
$(BACNET_BASIC)/service/h_noserv.c \
|
||||
$(BACNET_BASIC)/service/s_iam.c \
|
||||
$(BACNET_BASIC)/service/s_ihave.c \
|
||||
$(BACNET_BASIC)/sys/bsramfs.c \
|
||||
$(BACNET_BASIC)/sys/debug.c \
|
||||
$(BACNET_BASIC)/sys/datetime_mstimer.c \
|
||||
$(BACNET_BASIC)/sys/days.c \
|
||||
@@ -72,6 +75,7 @@ BASIC_SRC = \
|
||||
|
||||
BACNET_SRC = \
|
||||
$(BACNET_CORE)/abort.c \
|
||||
$(BACNET_CORE)/arf.c \
|
||||
$(BACNET_CORE)/bacaction.c \
|
||||
$(BACNET_CORE)/bacaddr.c \
|
||||
$(BACNET_CORE)/bacapp.c \
|
||||
@@ -177,6 +181,7 @@ BACNET_FLAGS += -DBIG_ENDIAN=0
|
||||
BACNET_FLAGS += -DMAX_TSM_TRANSACTIONS=0
|
||||
BACNET_FLAGS += -DMAX_CHARACTER_STRING_BYTES=64
|
||||
BACNET_FLAGS += -DMAX_OCTET_STRING_BYTES=64
|
||||
BACNET_FLAGS += -DBACFILE
|
||||
BACNET_FLAGS += -DBACAPP_MINIMAL
|
||||
BACNET_FLAGS += -DBACNET_STACK_DEPRECATED_DISABLE
|
||||
# if called from root Makefile, PRINT was already defined
|
||||
|
||||
@@ -61,6 +61,8 @@ void bacnet_init(void)
|
||||
apdu_set_confirmed_handler(
|
||||
SERVICE_CONFIRMED_DEVICE_COMMUNICATION_CONTROL,
|
||||
handler_device_communication_control);
|
||||
apdu_set_confirmed_handler(
|
||||
SERVICE_CONFIRMED_ATOMIC_READ_FILE, handler_atomic_read_file);
|
||||
/* start the cyclic 1 second timer for DCC */
|
||||
mstimer_set(&DCC_Timer, DCC_CYCLE_SECONDS * 1000);
|
||||
}
|
||||
|
||||
@@ -31,6 +31,9 @@
|
||||
#include "bacnet/basic/object/mso.h"
|
||||
#include "bacnet/basic/object/msv.h"
|
||||
#include "bacnet/basic/object/program.h"
|
||||
#if defined(BACFILE)
|
||||
#include "bacnet/basic/object/bacfile.h"
|
||||
#endif
|
||||
#if (BACNET_PROTOCOL_REVISION >= 17)
|
||||
#include "bacnet/basic/object/netport.h"
|
||||
#endif
|
||||
@@ -94,6 +97,11 @@ static struct my_object_functions {
|
||||
Program_Index_To_Instance, Program_Valid_Instance,
|
||||
Program_Object_Name, Program_Read_Property,
|
||||
Program_Write_Property, Program_Property_Lists},
|
||||
#if defined(BACFILE)
|
||||
{ OBJECT_FILE, bacfile_init, bacfile_count, bacfile_index_to_instance,
|
||||
bacfile_valid_instance, bacfile_object_name, bacfile_read_property,
|
||||
bacfile_write_property, BACfile_Property_Lists },
|
||||
#endif
|
||||
#if (BACNET_PROTOCOL_REVISION >= 17)
|
||||
{ OBJECT_NETWORK_PORT, Network_Port_Init, Network_Port_Count,
|
||||
Network_Port_Index_To_Instance, Network_Port_Valid_Instance,
|
||||
|
||||
+26
-4
@@ -15,7 +15,10 @@
|
||||
#include "stm32f4xx_rcc.h"
|
||||
#include "stm32f4xx_rng.h"
|
||||
#include "system_stm32f4xx.h"
|
||||
#include "bacnet/basic/object/bacfile.h"
|
||||
#include "bacnet/basic/object/device.h"
|
||||
#include "bacnet/basic/object/program.h"
|
||||
#include "bacnet/basic/sys/bsramfs.h"
|
||||
#include "bacnet/basic/sys/mstimer.h"
|
||||
#include "bacnet/basic/sys/ringbuf.h"
|
||||
#include "bacnet/datalink/datalink.h"
|
||||
@@ -88,6 +91,7 @@ static const char *UBASIC_Program_3 =
|
||||
"end;";
|
||||
/* uBASIC data tree for each program running */
|
||||
static struct ubasic_data UBASIC_Data[3];
|
||||
static struct bacnet_file_sramfs_data Static_Files[3];
|
||||
|
||||
/**
|
||||
* @brief Called from _write() function from printf and friends
|
||||
@@ -105,6 +109,7 @@ int __io_putchar(int ch)
|
||||
*/
|
||||
int main(void)
|
||||
{
|
||||
size_t i;
|
||||
/*At this stage the microcontroller clock setting is already configured,
|
||||
this is done through SystemInit() function which is called from startup
|
||||
file (startup_stm32f4xx.s) before to branch to application main.
|
||||
@@ -165,11 +170,28 @@ int main(void)
|
||||
}
|
||||
/* initialize application layer*/
|
||||
bacnet_init();
|
||||
/* configure a program */
|
||||
bacfile_sramfs_init();
|
||||
/* configure the program object and loop time */
|
||||
Program_UBASIC_Init(10);
|
||||
Program_UBASIC_Create(1, &UBASIC_Data[0], UBASIC_Program_1);
|
||||
Program_UBASIC_Create(2, &UBASIC_Data[1], UBASIC_Program_2);
|
||||
Program_UBASIC_Create(3, &UBASIC_Data[2], UBASIC_Program_3);
|
||||
/* create the uBASIC programs and link to file objects */
|
||||
Static_Files[0].data = (char *)UBASIC_Program_1;
|
||||
Static_Files[0].size = strlen(UBASIC_Program_1);
|
||||
Static_Files[0].pathname = "/program1.bas";
|
||||
Static_Files[1].data = (char *)UBASIC_Program_2;
|
||||
Static_Files[1].size = strlen(UBASIC_Program_2);
|
||||
Static_Files[1].pathname = "/program2.bas";
|
||||
Static_Files[2].data = (char *)UBASIC_Program_3;
|
||||
Static_Files[2].size = strlen(UBASIC_Program_3);
|
||||
Static_Files[2].pathname = "/program3.bas";
|
||||
for (i = 0; i < ARRAY_SIZE(Static_Files); i++) {
|
||||
bacfile_create(1 + i);
|
||||
bacfile_pathname_set(1 + i, Static_Files[i].pathname);
|
||||
bacfile_read_only_set(1 + i, true);
|
||||
bacfile_sramfs_add(&Static_Files[i]);
|
||||
Program_UBASIC_Create(1 + i, &UBASIC_Data[i], Static_Files[i].data);
|
||||
Program_Instance_Of_Set(1 + i, Static_Files[i].pathname);
|
||||
}
|
||||
/* loop forever */
|
||||
for (;;) {
|
||||
led_task();
|
||||
bacnet_task();
|
||||
|
||||
Reference in New Issue
Block a user