#include #ifndef AP_NETWORKING_ENABLED #define AP_NETWORKING_ENABLED 0 #endif #ifndef AP_NETWORKING_BACKEND_DEFAULT_ENABLED #define AP_NETWORKING_BACKEND_DEFAULT_ENABLED AP_NETWORKING_ENABLED #endif #ifndef AP_NETWORKING_CONTROLS_HOST_IP_SETTINGS_ENABLED // AP_NETWORKING_CONTROLS_HOST_IP_SETTINGS_ENABLED should only be true if we have the ability to // change the IP address. If not then the IP, GW, NetMask, MAC and DHCP params are hidden. // This does not mean that the system/OS does not have the ability to set the IP, just that // we have no control from this scope. For example, Linux systems (including SITL) have // their own DHCP client running but we have no control over it. #define AP_NETWORKING_CONTROLS_HOST_IP_SETTINGS_ENABLED (CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS) #endif // --------------------------- // Backends // --------------------------- #ifndef AP_NETWORKING_BACKEND_CHIBIOS #define AP_NETWORKING_BACKEND_CHIBIOS (AP_NETWORKING_BACKEND_DEFAULT_ENABLED && (CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS)) #endif #ifndef AP_NETWORKING_BACKEND_SITL #define AP_NETWORKING_BACKEND_SITL (AP_NETWORKING_BACKEND_DEFAULT_ENABLED && (CONFIG_HAL_BOARD == HAL_BOARD_SITL)) #endif #define AP_NETWORKING_SOCKETS_ENABLED (HAL_OS_SOCKETS || AP_NETWORKING_BACKEND_CHIBIOS) // --------------------------- // IP Features // --------------------------- #ifndef AP_NETWORKING_DHCP_AVAILABLE // AP_NETWORKING_DHCP_AVAILABLE should only be true if, by setting the NET_DHCP parameter, // we have the ability to turn on/off the DHCP client which effects the assigned IP address. // Otherwise, param NET_DHCP will be hidden. This does not mean that the system/OS does not // have DHCP, just that we have no control from this scope. For example, Linux systems // (including SITL) have their own DHCP client running but we have no control over it. #define AP_NETWORKING_DHCP_AVAILABLE (AP_NETWORKING_CONTROLS_HOST_IP_SETTINGS_ENABLED || AP_NETWORKING_BACKEND_CHIBIOS) #endif // --------------------------- // Below are default params // --------------------------- // Default DHCP #ifndef AP_NETWORKING_DEFAULT_DHCP_ENABLE #define AP_NETWORKING_DEFAULT_DHCP_ENABLE AP_NETWORKING_DHCP_AVAILABLE #endif // Default Static IP Address: 192.168.13.14 #ifndef AP_NETWORKING_DEFAULT_STATIC_IP_ADDR #define AP_NETWORKING_DEFAULT_STATIC_IP_ADDR "192.168.13.14" #endif // Default Netmask: 24 // Note, the netmask is the number of consecutive bits #ifndef AP_NETWORKING_DEFAULT_NETMASK #define AP_NETWORKING_DEFAULT_NETMASK 24 // 255.255.255.0 (for 10.0.xxx.xxx or 172.xxx.xxx.xxx type networks) // #define AP_NETWORKING_DEFAULT_NETMASK 16 // 255.255.0.0 (for 192.168.xxx.xxxx type networks) #endif // Default Static IP Address: 192.168.13.1 #ifndef AP_NETWORKING_DEFAULT_STATIC_GW_ADDR #define AP_NETWORKING_DEFAULT_STATIC_GW_ADDR "192.168.13.1" #endif // Default MAC Address: C2:AF:51:03:CF:46 // Note, lower 3 bytes (ADDR3,4,5) will be replaced with the platform UUID #ifndef AP_NETWORKING_DEFAULT_MAC_ADDR #define AP_NETWORKING_DEFAULT_MAC_ADDR "C2:AF:51:03:CF:46" #endif #ifndef AP_NETWORKING_TESTS_ENABLED #define AP_NETWORKING_TESTS_ENABLED 0 #endif #if AP_NETWORKING_TESTS_ENABLED #ifndef AP_NETWORKING_TEST_IP #define AP_NETWORKING_TEST_IP "192.168.13.2" #endif #endif #ifndef AP_NETWORKING_NUM_PORTS #define AP_NETWORKING_NUM_PORTS 4 #endif