Consolodated the datalink environment variable for building demos on Linux and Windows into a single module (dlenv). Adjusted most demo makefiles.
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
#Makefile to build BACnet Application for the Linux Port
|
#Makefile to build BACnet Application for GCC compiler
|
||||||
CC = gcc
|
CC = gcc
|
||||||
|
|
||||||
TARGET = bacdcc
|
TARGET = bacdcc
|
||||||
@@ -30,7 +30,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -49,6 +49,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
|
#include "dlenv.h"
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
||||||
@@ -141,92 +142,6 @@ static void Init_Service_Handlers(
|
|||||||
apdu_set_reject_handler(MyRejectHandler);
|
apdu_set_reject_handler(MyRejectHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf
|
|
||||||
("DeviceCommunicationControl: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
BACNET_ADDRESS src = {
|
BACNET_ADDRESS src = {
|
||||||
0}; /* address where message came from */
|
0}; /* address where message came from */
|
||||||
@@ -270,7 +185,7 @@ int main(int argc, char *argv[]) {
|
|||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
address_init();
|
address_init();
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -49,6 +49,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
|
#include "dlenv.h"
|
||||||
#include "keylist.h"
|
#include "keylist.h"
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
@@ -310,91 +311,6 @@ static uint8_t Read_Properties(
|
|||||||
return invoke_id;
|
return invoke_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf("EPICS: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
BACNET_ADDRESS src = {
|
BACNET_ADDRESS src = {
|
||||||
0}; /* address where message came from */
|
0}; /* address where message came from */
|
||||||
@@ -428,7 +344,7 @@ int main(int argc, char *argv[]) {
|
|||||||
Object_List = Keylist_Create();
|
Object_List = Keylist_Create();
|
||||||
address_init();
|
address_init();
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
||||||
|
|||||||
@@ -0,0 +1,131 @@
|
|||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright (C) 2009 Steve Karg <skarg@users.sourceforge.net>
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
* a copy of this software and associated documentation files (the
|
||||||
|
* "Software"), to deal in the Software without restriction, including
|
||||||
|
* without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
* permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
* the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included
|
||||||
|
* in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||||
|
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||||
|
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
|
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
*********************************************************************/
|
||||||
|
|
||||||
|
/* environment variables used for the command line tools */
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include "config.h"
|
||||||
|
#include "bacdef.h"
|
||||||
|
#include "apdu.h"
|
||||||
|
#include "datalink.h"
|
||||||
|
#include "handlers.h"
|
||||||
|
#include "client.h"
|
||||||
|
|
||||||
|
void dlenv_init(
|
||||||
|
void)
|
||||||
|
{
|
||||||
|
char *pEnv = NULL;
|
||||||
|
#if defined(BACDL_BIP) && BBMD_ENABLED
|
||||||
|
long bbmd_port = 0xBAC0;
|
||||||
|
long bbmd_address = 0;
|
||||||
|
long bbmd_timetolive_seconds = 60000;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(BACDL_ALL)
|
||||||
|
pEnv = getenv("BACNET_DATALINK");
|
||||||
|
if (pEnv) {
|
||||||
|
datalink_set(pEnv));
|
||||||
|
} else {
|
||||||
|
datalink_set(NULL);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(BACDL_BIP)
|
||||||
|
pEnv = getenv("BACNET_IP_PORT");
|
||||||
|
if (pEnv) {
|
||||||
|
bip_set_port(strtol(pEnv, NULL, 0));
|
||||||
|
} else {
|
||||||
|
bip_set_port(0xBAC0);
|
||||||
|
}
|
||||||
|
#elif defined(BACDL_MSTP)
|
||||||
|
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
||||||
|
if (pEnv) {
|
||||||
|
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
||||||
|
} else {
|
||||||
|
dlmstp_set_max_info_frames(1);
|
||||||
|
}
|
||||||
|
pEnv = getenv("BACNET_MAX_MASTER");
|
||||||
|
if (pEnv) {
|
||||||
|
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
||||||
|
} else {
|
||||||
|
dlmstp_set_max_master(127);
|
||||||
|
}
|
||||||
|
pEnv = getenv("BACNET_MSTP_BAUD");
|
||||||
|
if (pEnv) {
|
||||||
|
dlmstp_set_baud_rate(strtol(pEnv, NULL, 0));
|
||||||
|
} else {
|
||||||
|
dlmstp_set_baud_rate(38400);
|
||||||
|
}
|
||||||
|
pEnv = getenv("BACNET_MSTP_MAC");
|
||||||
|
if (pEnv) {
|
||||||
|
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
||||||
|
} else {
|
||||||
|
dlmstp_set_mac_address(127);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
pEnv = getenv("BACNET_APDU_TIMEOUT");
|
||||||
|
if (pEnv) {
|
||||||
|
apdu_timeout_set(strtol(pEnv, NULL, 0));
|
||||||
|
fprintf(stderr, "BACNET_APDU_TIMEOUT=%s\r\n", pEnv);
|
||||||
|
} else {
|
||||||
|
#if defined(BACDL_MSTP)
|
||||||
|
apdu_timeout_set(60000);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
#if defined(BACDL_BIP) && BBMD_ENABLED
|
||||||
|
pEnv = getenv("BACNET_BBMD_PORT");
|
||||||
|
if (pEnv) {
|
||||||
|
bbmd_port = strtol(pEnv, NULL, 0);
|
||||||
|
if (bbmd_port > 0xFFFF) {
|
||||||
|
bbmd_port = 0xBAC0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
||||||
|
if (pEnv) {
|
||||||
|
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
||||||
|
if (bbmd_timetolive_seconds > 0xFFFF) {
|
||||||
|
bbmd_timetolive_seconds = 0xFFFF;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
||||||
|
if (pEnv) {
|
||||||
|
bbmd_address = bip_getaddrbyname(pEnv);
|
||||||
|
if (bbmd_address) {
|
||||||
|
struct in_addr addr;
|
||||||
|
addr.s_addr = bbmd_address;
|
||||||
|
fprintf(stderr,
|
||||||
|
"Registering with BBMD at %s:%ld for %ld seconds\n",
|
||||||
|
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
||||||
|
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
||||||
|
bbmd_timetolive_seconds);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
@@ -30,7 +30,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -44,9 +44,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
#if defined(BACDL_MSTP)
|
#include "dlenv.h"
|
||||||
#include "rs485.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
||||||
@@ -103,91 +101,6 @@ static void Init_Service_Handlers(
|
|||||||
apdu_set_reject_handler(MyRejectHandler);
|
apdu_set_reject_handler(MyRejectHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf("WhoIs: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
unsigned arg_count = 0;
|
unsigned arg_count = 0;
|
||||||
|
|
||||||
@@ -234,7 +147,7 @@ int main(int argc, char *argv[]) {
|
|||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
address_init();
|
address_init();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* send the request */
|
/* send the request */
|
||||||
Send_I_Am_Router_To_Network(Target_Router_Networks);
|
Send_I_Am_Router_To_Network(Target_Router_Networks);
|
||||||
|
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -46,9 +46,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
#if defined(BACDL_MSTP)
|
#include "dlenv.h"
|
||||||
#include "rs485.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
||||||
@@ -225,91 +223,6 @@ static void Init_Service_Handlers(
|
|||||||
apdu_set_reject_handler(MyRejectHandler);
|
apdu_set_reject_handler(MyRejectHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf("NPDU: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
static void address_parse(BACNET_ADDRESS * dst,
|
static void address_parse(BACNET_ADDRESS * dst,
|
||||||
int argc, char *argv[]) {
|
int argc, char *argv[]) {
|
||||||
unsigned mac[6];
|
unsigned mac[6];
|
||||||
@@ -393,7 +306,7 @@ int main(int argc, char *argv[]) {
|
|||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
address_init();
|
address_init();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
timeout_seconds = apdu_timeout() / 1000;
|
timeout_seconds = apdu_timeout() / 1000;
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -48,6 +48,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
|
#include "dlenv.h"
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
||||||
@@ -196,92 +197,6 @@ static void Init_Service_Handlers(
|
|||||||
apdu_set_reject_handler(MyRejectHandler);
|
apdu_set_reject_handler(MyRejectHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf
|
|
||||||
("AtomicReadFile: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
BACNET_ADDRESS src = {
|
BACNET_ADDRESS src = {
|
||||||
0}; /* address where message came from */
|
0}; /* address where message came from */
|
||||||
@@ -322,7 +237,7 @@ int main(int argc, char *argv[]) {
|
|||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
address_init();
|
address_init();
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
#Makefile to build BACnet Application for the Linux Port
|
#Makefile to build BACnet Application using GCC compiler
|
||||||
# Compiler to use
|
# Compiler to use
|
||||||
CC = gcc
|
CC = gcc
|
||||||
# Executable file name
|
# Executable file name
|
||||||
@@ -30,7 +30,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -51,6 +51,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
|
#include "dlenv.h"
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
||||||
@@ -132,98 +133,6 @@ static void Init_Service_Handlers(
|
|||||||
apdu_set_reject_handler(MyRejectHandler);
|
apdu_set_reject_handler(MyRejectHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
fprintf(stderr, "BACNET_MSTP_BAUD=%s\r\n", pEnv);
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_APDU_TIMEOUT");
|
|
||||||
if (pEnv) {
|
|
||||||
apdu_timeout_set(strtol(pEnv, NULL, 0));
|
|
||||||
fprintf(stderr, "BACNET_APDU_TIMEOUT=%s\r\n", pEnv);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf
|
|
||||||
("ReadProperty: Registering with BBMD at %s:%ld for %ld seconds\r\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
BACNET_ADDRESS src = {
|
BACNET_ADDRESS src = {
|
||||||
0}; /* address where message came from */
|
0}; /* address where message came from */
|
||||||
@@ -309,7 +218,7 @@ int main(int argc, char *argv[]) {
|
|||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
address_init();
|
address_init();
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -52,6 +52,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
|
#include "dlenv.h"
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
||||||
@@ -130,92 +131,6 @@ static void Init_Service_Handlers(
|
|||||||
apdu_set_reject_handler(MyRejectHandler);
|
apdu_set_reject_handler(MyRejectHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf
|
|
||||||
("ReadProperty: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void cleanup(void) {
|
void cleanup(void) {
|
||||||
BACNET_READ_ACCESS_DATA *rpm_object;
|
BACNET_READ_ACCESS_DATA *rpm_object;
|
||||||
BACNET_READ_ACCESS_DATA *old_rpm_object;
|
BACNET_READ_ACCESS_DATA *old_rpm_object;
|
||||||
@@ -375,7 +290,7 @@ int main(int argc, char *argv[]) {
|
|||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
address_init();
|
address_init();
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -49,6 +49,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
|
#include "dlenv.h"
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
||||||
@@ -136,92 +137,6 @@ static void Init_Service_Handlers(
|
|||||||
apdu_set_reject_handler(MyRejectHandler);
|
apdu_set_reject_handler(MyRejectHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf
|
|
||||||
("ReinitDevice: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
BACNET_ADDRESS src = {
|
BACNET_ADDRESS src = {
|
||||||
0}; /* address where message came from */
|
0}; /* address where message came from */
|
||||||
@@ -264,7 +179,7 @@ int main(int argc, char *argv[]) {
|
|||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
address_init();
|
address_init();
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
timeout_seconds = (apdu_timeout() / 1000) * apdu_retries();
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -33,6 +33,7 @@
|
|||||||
#include "bacdef.h"
|
#include "bacdef.h"
|
||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
|
#include "dlenv.h"
|
||||||
#include "bacdcode.h"
|
#include "bacdcode.h"
|
||||||
#include "npdu.h"
|
#include "npdu.h"
|
||||||
#include "apdu.h"
|
#include "apdu.h"
|
||||||
@@ -46,9 +47,6 @@
|
|||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
#include "lc.h"
|
#include "lc.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#if defined(BACDL_MSTP)
|
|
||||||
#include "rs485.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* This is an example server application using the BACnet Stack */
|
/* This is an example server application using the BACnet Stack */
|
||||||
|
|
||||||
@@ -100,92 +98,6 @@ static void cleanup(
|
|||||||
datalink_cleanup();
|
datalink_cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
BIP_Debug = true;
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf("Server: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
BACNET_ADDRESS src = {
|
BACNET_ADDRESS src = {
|
||||||
0}; /* address where message came from */
|
0}; /* address where message came from */
|
||||||
@@ -203,7 +115,7 @@ int main(int argc, char *argv[]) {
|
|||||||
"BACnet Device ID: %u\n" "Max APDU: %d\n", BACnet_Version,
|
"BACnet Device ID: %u\n" "Max APDU: %d\n", BACnet_Version,
|
||||||
Device_Object_Instance_Number(), MAX_APDU);
|
Device_Object_Instance_Number(), MAX_APDU);
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
atexit(cleanup);
|
atexit(cleanup);
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -44,6 +44,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
|
#include "dlenv.h"
|
||||||
|
|
||||||
/* buffer used for receive */
|
/* buffer used for receive */
|
||||||
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
static uint8_t Rx_Buf[MAX_MPDU] = { 0 };
|
||||||
@@ -105,92 +106,6 @@ static void Init_Service_Handlers(
|
|||||||
apdu_set_reject_handler(MyRejectHandler);
|
apdu_set_reject_handler(MyRejectHandler);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Init_DataLink(
|
|
||||||
void)
|
|
||||||
{
|
|
||||||
char *pEnv = NULL;
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
long bbmd_port = 0xBAC0;
|
|
||||||
long bbmd_address = 0;
|
|
||||||
long bbmd_timetolive_seconds = 60000;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_ALL)
|
|
||||||
pEnv = getenv("BACNET_DATALINK");
|
|
||||||
if (pEnv) {
|
|
||||||
datalink_set(pEnv));
|
|
||||||
} else {
|
|
||||||
datalink_set(NULL);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(BACDL_BIP)
|
|
||||||
pEnv = getenv("BACNET_IP_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bip_set_port(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
bip_set_port(0xBAC0);
|
|
||||||
}
|
|
||||||
#elif defined(BACDL_MSTP)
|
|
||||||
pEnv = getenv("BACNET_MAX_INFO_FRAMES");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_info_frames(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_info_frames(1);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MAX_MASTER");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_max_master(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_max_master(127);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
|
||||||
if (pEnv) {
|
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
RS485_Set_Baud_Rate(38400);
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
|
||||||
if (pEnv) {
|
|
||||||
dlmstp_set_mac_address(strtol(pEnv, NULL, 0));
|
|
||||||
} else {
|
|
||||||
dlmstp_set_mac_address(127);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#if defined(BACDL_BIP) && BBMD_ENABLED
|
|
||||||
pEnv = getenv("BACNET_BBMD_PORT");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_port = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_port > 0xFFFF) {
|
|
||||||
bbmd_port = 0xBAC0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_TIMETOLIVE");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_timetolive_seconds = strtol(pEnv, NULL, 0);
|
|
||||||
if (bbmd_timetolive_seconds > 0xFFFF) {
|
|
||||||
bbmd_timetolive_seconds = 0xFFFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
pEnv = getenv("BACNET_BBMD_ADDRESS");
|
|
||||||
if (pEnv) {
|
|
||||||
bbmd_address = bip_getaddrbyname(pEnv);
|
|
||||||
if (bbmd_address) {
|
|
||||||
struct in_addr addr;
|
|
||||||
addr.s_addr = bbmd_address;
|
|
||||||
printf
|
|
||||||
("TimeSync: Registering with BBMD at %s:%ld for %ld seconds\n",
|
|
||||||
inet_ntoa(addr), bbmd_port, bbmd_timetolive_seconds);
|
|
||||||
bvlc_register_with_bbmd(bbmd_address, bbmd_port,
|
|
||||||
bbmd_timetolive_seconds);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
int main(int argc, char *argv[]) {
|
int main(int argc, char *argv[]) {
|
||||||
BACNET_ADDRESS src = {
|
BACNET_ADDRESS src = {
|
||||||
0}; /* address where message came from */
|
0}; /* address where message came from */
|
||||||
@@ -227,7 +142,7 @@ int main(int argc, char *argv[]) {
|
|||||||
/* setup my info */
|
/* setup my info */
|
||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
/* configure the timeout values */
|
/* configure the timeout values */
|
||||||
last_seconds = time(NULL);
|
last_seconds = time(NULL);
|
||||||
timeout_seconds = apdu_timeout() / 1000;
|
timeout_seconds = apdu_timeout() / 1000;
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -48,6 +48,7 @@
|
|||||||
#include "handlers.h"
|
#include "handlers.h"
|
||||||
#include "client.h"
|
#include "client.h"
|
||||||
#include "txbuf.h"
|
#include "txbuf.h"
|
||||||
|
#include "dlenv.h"
|
||||||
|
|
||||||
static void Init_Service_Handlers(
|
static void Init_Service_Handlers(
|
||||||
void)
|
void)
|
||||||
@@ -107,9 +108,9 @@ static void Init_DataLink(
|
|||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
pEnv = getenv("BACNET_MSTP_BAUD");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
dlmstp_set_baud_rate(strtol(pEnv, NULL, 0));
|
||||||
} else {
|
} else {
|
||||||
RS485_Set_Baud_Rate(38400);
|
dlmstp_set_baud_rate(38400);
|
||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
pEnv = getenv("BACNET_MSTP_MAC");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
@@ -118,6 +119,15 @@ static void Init_DataLink(
|
|||||||
dlmstp_set_mac_address(127);
|
dlmstp_set_mac_address(127);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
pEnv = getenv("BACNET_APDU_TIMEOUT");
|
||||||
|
if (pEnv) {
|
||||||
|
apdu_timeout_set(strtol(pEnv, NULL, 0));
|
||||||
|
fprintf(stderr, "BACNET_APDU_TIMEOUT=%s\r\n", pEnv);
|
||||||
|
} else {
|
||||||
|
#if defined(BACDL_MSTP)
|
||||||
|
apdu_timeout_set(60000);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
@@ -273,7 +283,7 @@ int main(int argc, char *argv[]) {
|
|||||||
/* setup my info */
|
/* setup my info */
|
||||||
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
Device_Set_Object_Instance_Number(BACNET_MAX_INSTANCE);
|
||||||
Init_Service_Handlers();
|
Init_Service_Handlers();
|
||||||
Init_DataLink();
|
dlenv_init();
|
||||||
Send_UCOV_Notify(&Handler_Transmit_Buffer[0], &cov_data);
|
Send_UCOV_Notify(&Handler_Transmit_Buffer[0], &cov_data);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -146,9 +146,9 @@ static void Init_DataLink(
|
|||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
pEnv = getenv("BACNET_MSTP_BAUD");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
dlmstp_set_baud_rate(strtol(pEnv, NULL, 0));
|
||||||
} else {
|
} else {
|
||||||
RS485_Set_Baud_Rate(38400);
|
dlmstp_set_baud_rate(38400);
|
||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
pEnv = getenv("BACNET_MSTP_MAC");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
@@ -157,6 +157,15 @@ static void Init_DataLink(
|
|||||||
dlmstp_set_mac_address(127);
|
dlmstp_set_mac_address(127);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
pEnv = getenv("BACNET_APDU_TIMEOUT");
|
||||||
|
if (pEnv) {
|
||||||
|
apdu_timeout_set(strtol(pEnv, NULL, 0));
|
||||||
|
fprintf(stderr, "BACNET_APDU_TIMEOUT=%s\r\n", pEnv);
|
||||||
|
} else {
|
||||||
|
#if defined(BACDL_MSTP)
|
||||||
|
apdu_timeout_set(60000);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -181,9 +181,9 @@ static void Init_DataLink(
|
|||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
pEnv = getenv("BACNET_MSTP_BAUD");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
dlmstp_set_baud_rate(strtol(pEnv, NULL, 0));
|
||||||
} else {
|
} else {
|
||||||
RS485_Set_Baud_Rate(38400);
|
dlmstp_set_baud_rate(38400);
|
||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
pEnv = getenv("BACNET_MSTP_MAC");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
@@ -191,8 +191,16 @@ static void Init_DataLink(
|
|||||||
} else {
|
} else {
|
||||||
dlmstp_set_mac_address(127);
|
dlmstp_set_mac_address(127);
|
||||||
}
|
}
|
||||||
apdu_timeout_set(60000);
|
|
||||||
#endif
|
#endif
|
||||||
|
pEnv = getenv("BACNET_APDU_TIMEOUT");
|
||||||
|
if (pEnv) {
|
||||||
|
apdu_timeout_set(strtol(pEnv, NULL, 0));
|
||||||
|
fprintf(stderr, "BACNET_APDU_TIMEOUT=%s\r\n", pEnv);
|
||||||
|
} else {
|
||||||
|
#if defined(BACDL_MSTP)
|
||||||
|
apdu_timeout_set(60000);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -226,9 +226,9 @@ static void Init_DataLink(
|
|||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
pEnv = getenv("BACNET_MSTP_BAUD");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
dlmstp_set_baud_rate(strtol(pEnv, NULL, 0));
|
||||||
} else {
|
} else {
|
||||||
RS485_Set_Baud_Rate(38400);
|
dlmstp_set_baud_rate(38400);
|
||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
pEnv = getenv("BACNET_MSTP_MAC");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
@@ -237,6 +237,15 @@ static void Init_DataLink(
|
|||||||
dlmstp_set_mac_address(127);
|
dlmstp_set_mac_address(127);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
pEnv = getenv("BACNET_APDU_TIMEOUT");
|
||||||
|
if (pEnv) {
|
||||||
|
apdu_timeout_set(strtol(pEnv, NULL, 0));
|
||||||
|
fprintf(stderr, "BACNET_APDU_TIMEOUT=%s\r\n", pEnv);
|
||||||
|
} else {
|
||||||
|
#if defined(BACDL_MSTP)
|
||||||
|
apdu_timeout_set(60000);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -191,9 +191,9 @@ static void Init_DataLink(
|
|||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
pEnv = getenv("BACNET_MSTP_BAUD");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
dlmstp_set_baud_rate(strtol(pEnv, NULL, 0));
|
||||||
} else {
|
} else {
|
||||||
RS485_Set_Baud_Rate(38400);
|
dlmstp_set_baud_rate(38400);
|
||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
pEnv = getenv("BACNET_MSTP_MAC");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
@@ -202,6 +202,15 @@ static void Init_DataLink(
|
|||||||
dlmstp_set_mac_address(127);
|
dlmstp_set_mac_address(127);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
pEnv = getenv("BACNET_APDU_TIMEOUT");
|
||||||
|
if (pEnv) {
|
||||||
|
apdu_timeout_set(strtol(pEnv, NULL, 0));
|
||||||
|
fprintf(stderr, "BACNET_APDU_TIMEOUT=%s\r\n", pEnv);
|
||||||
|
} else {
|
||||||
|
#if defined(BACDL_MSTP)
|
||||||
|
apdu_timeout_set(60000);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ endif
|
|||||||
ifeq (${BACNET_PORT},win32)
|
ifeq (${BACNET_PORT},win32)
|
||||||
TARGET_BIN = ${TARGET}.exe
|
TARGET_BIN = ${TARGET}.exe
|
||||||
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
LIBRARY1=-L=$(BACNET_LIB_DIR),-l$(BACNET_LIB_NAME)
|
||||||
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi
|
LIBRARY2=-lws2_32,-lgcc,-lm,-liphlpapi,-lwinmm
|
||||||
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
LIBRARIES=$(LIBRARY1),$(LIBRARY2)
|
||||||
endif
|
endif
|
||||||
#build for release (default) or debug
|
#build for release (default) or debug
|
||||||
|
|||||||
@@ -191,9 +191,9 @@ static void Init_DataLink(
|
|||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_BAUD");
|
pEnv = getenv("BACNET_MSTP_BAUD");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
RS485_Set_Baud_Rate(strtol(pEnv, NULL, 0));
|
dlmstp_set_baud_rate(strtol(pEnv, NULL, 0));
|
||||||
} else {
|
} else {
|
||||||
RS485_Set_Baud_Rate(38400);
|
dlmstp_set_baud_rate(38400);
|
||||||
}
|
}
|
||||||
pEnv = getenv("BACNET_MSTP_MAC");
|
pEnv = getenv("BACNET_MSTP_MAC");
|
||||||
if (pEnv) {
|
if (pEnv) {
|
||||||
@@ -202,6 +202,15 @@ static void Init_DataLink(
|
|||||||
dlmstp_set_mac_address(127);
|
dlmstp_set_mac_address(127);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
pEnv = getenv("BACNET_APDU_TIMEOUT");
|
||||||
|
if (pEnv) {
|
||||||
|
apdu_timeout_set(strtol(pEnv, NULL, 0));
|
||||||
|
fprintf(stderr, "BACNET_APDU_TIMEOUT=%s\r\n", pEnv);
|
||||||
|
} else {
|
||||||
|
#if defined(BACDL_MSTP)
|
||||||
|
apdu_timeout_set(60000);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
if (!datalink_init(getenv("BACNET_IFACE"))) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,38 @@
|
|||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright (C) 2009 Steve Karg <skarg@users.sourceforge.net>
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
* a copy of this software and associated documentation files (the
|
||||||
|
* "Software"), to deal in the Software without restriction, including
|
||||||
|
* without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
* distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
* permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
* the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included
|
||||||
|
* in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||||
|
* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||||
|
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
|
||||||
|
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
|
||||||
|
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*
|
||||||
|
*********************************************************************/
|
||||||
|
#ifndef DLENV_H
|
||||||
|
#define DLENV_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
void dlenv_init(
|
||||||
|
void);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
#endif
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
#Makefile to build BACnet Library for the Linux Port
|
#Makefile to build BACnet Library with GCC
|
||||||
|
|
||||||
# tools
|
# tools
|
||||||
CC = gcc
|
CC = gcc
|
||||||
@@ -74,6 +74,7 @@ CORE_SRC = \
|
|||||||
$(BACNET_CORE)/version.c
|
$(BACNET_CORE)/version.c
|
||||||
|
|
||||||
HANDLER_SRC = \
|
HANDLER_SRC = \
|
||||||
|
$(BACNET_HANDLER)/dlenv.c \
|
||||||
$(BACNET_HANDLER)/txbuf.c \
|
$(BACNET_HANDLER)/txbuf.c \
|
||||||
$(BACNET_HANDLER)/noserv.c \
|
$(BACNET_HANDLER)/noserv.c \
|
||||||
$(BACNET_HANDLER)/h_npdu.c \
|
$(BACNET_HANDLER)/h_npdu.c \
|
||||||
|
|||||||
@@ -148,6 +148,9 @@
|
|||||||
<Unit filename="..\demo\handler\txbuf.c">
|
<Unit filename="..\demo\handler\txbuf.c">
|
||||||
<Option compilerVar="CC" />
|
<Option compilerVar="CC" />
|
||||||
</Unit>
|
</Unit>
|
||||||
|
<Unit filename="..\demo\handler\dlenv.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
<Unit filename="..\demo\object\ai.c">
|
<Unit filename="..\demo\object\ai.c">
|
||||||
<Option compilerVar="CC" />
|
<Option compilerVar="CC" />
|
||||||
</Unit>
|
</Unit>
|
||||||
|
|||||||
@@ -111,6 +111,7 @@
|
|||||||
<Unit filename="..\include\timesync.h" />
|
<Unit filename="..\include\timesync.h" />
|
||||||
<Unit filename="..\include\tsm.h" />
|
<Unit filename="..\include\tsm.h" />
|
||||||
<Unit filename="..\include\txbuf.h" />
|
<Unit filename="..\include\txbuf.h" />
|
||||||
|
<Unit filename="..\include\dlenv.h" />
|
||||||
<Unit filename="..\include\version.h" />
|
<Unit filename="..\include\version.h" />
|
||||||
<Unit filename="..\include\whohas.h" />
|
<Unit filename="..\include\whohas.h" />
|
||||||
<Unit filename="..\include\whois.h" />
|
<Unit filename="..\include\whois.h" />
|
||||||
|
|||||||
@@ -72,7 +72,9 @@ CORE3_SRC = $(BACNET_CORE)\arf.c \
|
|||||||
$(BACNET_CORE)\whois.c \
|
$(BACNET_CORE)\whois.c \
|
||||||
$(BACNET_CORE)\wp.c
|
$(BACNET_CORE)\wp.c
|
||||||
|
|
||||||
HANDLER_SRC = $(BACNET_HANDLER)\txbuf.c \
|
HANDLER_SRC = \
|
||||||
|
$(BACNET_HANDLER)\dlenv.c \
|
||||||
|
$(BACNET_HANDLER)\txbuf.c \
|
||||||
$(BACNET_HANDLER)\noserv.c \
|
$(BACNET_HANDLER)\noserv.c \
|
||||||
$(BACNET_HANDLER)\h_whois.c \
|
$(BACNET_HANDLER)\h_whois.c \
|
||||||
$(BACNET_HANDLER)\h_npdu.c \
|
$(BACNET_HANDLER)\h_npdu.c \
|
||||||
|
|||||||
@@ -329,6 +329,10 @@ SOURCE=..\..\..\demo\handler\txbuf.c
|
|||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|
||||||
|
SOURCE=..\..\..\demo\handler\dlenv.c
|
||||||
|
# End Source File
|
||||||
|
# Begin Source File
|
||||||
|
|
||||||
SOURCE=..\..\..\src\version.c
|
SOURCE=..\..\..\src\version.c
|
||||||
# End Source File
|
# End Source File
|
||||||
# Begin Source File
|
# Begin Source File
|
||||||
|
|||||||
@@ -44,36 +44,18 @@
|
|||||||
<Add directory="..\..\demo\handler" />
|
<Add directory="..\..\demo\handler" />
|
||||||
<Add directory="..\..\demo\object" />
|
<Add directory="..\..\demo\object" />
|
||||||
</Compiler>
|
</Compiler>
|
||||||
<Unit filename="..\..\src\bacaddr.c">
|
<Linker>
|
||||||
<Option compilerVar="CC" />
|
<Add library="winmm" />
|
||||||
</Unit>
|
</Linker>
|
||||||
<Unit filename="..\..\include\bacaddr.h" />
|
<Unit filename="..\..\include\bacaddr.h" />
|
||||||
<Unit filename="..\..\include\bacdef.h" />
|
<Unit filename="..\..\include\bacdef.h" />
|
||||||
<Unit filename="..\..\src\bacint.c">
|
|
||||||
<Option compilerVar="CC" />
|
|
||||||
</Unit>
|
|
||||||
<Unit filename="..\..\include\bacint.h" />
|
<Unit filename="..\..\include\bacint.h" />
|
||||||
<Unit filename="..\..\src\crc.c">
|
|
||||||
<Option compilerVar="CC" />
|
|
||||||
</Unit>
|
|
||||||
<Unit filename="..\..\include\crc.h" />
|
<Unit filename="..\..\include\crc.h" />
|
||||||
<Unit filename="..\..\include\datalink.h" />
|
<Unit filename="..\..\include\datalink.h" />
|
||||||
<Unit filename="..\..\include\dlmstp.h" />
|
<Unit filename="..\..\include\dlmstp.h" />
|
||||||
<Unit filename="..\..\src\indtext.c">
|
|
||||||
<Option compilerVar="CC" />
|
|
||||||
</Unit>
|
|
||||||
<Unit filename="..\..\include\indtext.h" />
|
<Unit filename="..\..\include\indtext.h" />
|
||||||
<Unit filename="..\..\src\mstp.c">
|
|
||||||
<Option compilerVar="CC" />
|
|
||||||
</Unit>
|
|
||||||
<Unit filename="..\..\include\mstp.h" />
|
<Unit filename="..\..\include\mstp.h" />
|
||||||
<Unit filename="..\..\src\mstptext.c">
|
|
||||||
<Option compilerVar="CC" />
|
|
||||||
</Unit>
|
|
||||||
<Unit filename="..\..\include\mstptext.h" />
|
<Unit filename="..\..\include\mstptext.h" />
|
||||||
<Unit filename="..\..\src\npdu.c">
|
|
||||||
<Option compilerVar="CC" />
|
|
||||||
</Unit>
|
|
||||||
<Unit filename="..\..\include\npdu.h" />
|
<Unit filename="..\..\include\npdu.h" />
|
||||||
<Unit filename="dlmstp.c">
|
<Unit filename="dlmstp.c">
|
||||||
<Option compilerVar="CC" />
|
<Option compilerVar="CC" />
|
||||||
@@ -82,6 +64,27 @@
|
|||||||
<Option compilerVar="CC" />
|
<Option compilerVar="CC" />
|
||||||
</Unit>
|
</Unit>
|
||||||
<Unit filename="rs485.h" />
|
<Unit filename="rs485.h" />
|
||||||
|
<Unit filename="..\..\src\bacaddr.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="..\..\src\bacint.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="..\..\src\crc.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="..\..\src\indtext.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="..\..\src\mstp.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="..\..\src\mstptext.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
|
<Unit filename="..\..\src\npdu.c">
|
||||||
|
<Option compilerVar="CC" />
|
||||||
|
</Unit>
|
||||||
<Extensions>
|
<Extensions>
|
||||||
<code_completion />
|
<code_completion />
|
||||||
<envvars />
|
<envvars />
|
||||||
|
|||||||
@@ -116,8 +116,6 @@ static void RS485_Print_Error(
|
|||||||
void)
|
void)
|
||||||
{
|
{
|
||||||
LPVOID lpMsgBuf;
|
LPVOID lpMsgBuf;
|
||||||
DWORD dwExtSize;
|
|
||||||
DWORD dwErr;
|
|
||||||
|
|
||||||
FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, NULL, GetLastError(), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), /* Default language */
|
FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, NULL, GetLastError(), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), /* Default language */
|
||||||
(LPTSTR) & lpMsgBuf, 0, NULL);
|
(LPTSTR) & lpMsgBuf, 0, NULL);
|
||||||
|
|||||||
Reference in New Issue
Block a user