mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 14:48:28 -04:00
AP_Periph: clean up node ID parameter handling
Properly document the range and behavior. Rename storage variable as it doesn't connect to the DNA preferred ID feature.
This commit is contained in:
parent
aca624486d
commit
dcd34dd39e
@ -86,9 +86,9 @@ const AP_Param::Info AP_Periph_FW::var_info[] = {
|
|||||||
GSCALAR(format_version, "FORMAT_VERSION", 0),
|
GSCALAR(format_version, "FORMAT_VERSION", 0),
|
||||||
|
|
||||||
// @Param: CAN_NODE
|
// @Param: CAN_NODE
|
||||||
// @DisplayName: UAVCAN node that is used for this network
|
// @DisplayName: DroneCAN node ID used by this node on all networks
|
||||||
// @Description: UAVCAN node should be set implicitly or 0 for dynamic node allocation
|
// @Description: Value of 0 requests any ID from a DNA server, any other value sets that ID ignoring DNA
|
||||||
// @Range: 0 250
|
// @Range: 0 127
|
||||||
// @User: Advanced
|
// @User: Advanced
|
||||||
// @RebootRequired: True
|
// @RebootRequired: True
|
||||||
GSCALAR(can_node, "CAN_NODE", HAL_CAN_DEFAULT_NODE_ID),
|
GSCALAR(can_node, "CAN_NODE", HAL_CAN_DEFAULT_NODE_ID),
|
||||||
|
@ -125,10 +125,7 @@ HAL_GPIO_PIN_TERMCAN1
|
|||||||
};
|
};
|
||||||
#endif // CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS && defined(HAL_GPIO_PIN_TERMCAN1)
|
#endif // CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS && defined(HAL_GPIO_PIN_TERMCAN1)
|
||||||
|
|
||||||
#ifndef HAL_CAN_DEFAULT_NODE_ID
|
uint8_t user_set_node_id = HAL_CAN_DEFAULT_NODE_ID;
|
||||||
#define HAL_CAN_DEFAULT_NODE_ID CANARD_BROADCAST_NODE_ID
|
|
||||||
#endif
|
|
||||||
uint8_t PreferredNodeID = HAL_CAN_DEFAULT_NODE_ID;
|
|
||||||
|
|
||||||
#ifndef AP_PERIPH_PROBE_CONTINUOUS
|
#ifndef AP_PERIPH_PROBE_CONTINUOUS
|
||||||
#define AP_PERIPH_PROBE_CONTINUOUS 0
|
#define AP_PERIPH_PROBE_CONTINUOUS 0
|
||||||
@ -1550,7 +1547,7 @@ bool AP_Periph_FW::can_do_dna()
|
|||||||
// Structure of the request is documented in the DSDL definition
|
// Structure of the request is documented in the DSDL definition
|
||||||
// See http://uavcan.org/Specification/6._Application_level_functions/#dynamic-node-id-allocation
|
// See http://uavcan.org/Specification/6._Application_level_functions/#dynamic-node-id-allocation
|
||||||
uint8_t allocation_request[CANARD_CAN_FRAME_MAX_DATA_LEN - 1];
|
uint8_t allocation_request[CANARD_CAN_FRAME_MAX_DATA_LEN - 1];
|
||||||
allocation_request[0] = (uint8_t)(PreferredNodeID << 1U);
|
allocation_request[0] = 0; // we are only called if the user has not set an ID, so request any ID
|
||||||
|
|
||||||
if (dronecan.node_id_allocation_unique_id_offset == 0) {
|
if (dronecan.node_id_allocation_unique_id_offset == 0) {
|
||||||
allocation_request[0] |= 1; // First part of unique ID
|
allocation_request[0] |= 1; // First part of unique ID
|
||||||
@ -1590,7 +1587,7 @@ void AP_Periph_FW::can_start()
|
|||||||
node_status.uptime_sec = AP_HAL::millis() / 1000U;
|
node_status.uptime_sec = AP_HAL::millis() / 1000U;
|
||||||
|
|
||||||
if (g.can_node >= 0 && g.can_node < 128) {
|
if (g.can_node >= 0 && g.can_node < 128) {
|
||||||
PreferredNodeID = g.can_node;
|
user_set_node_id = g.can_node;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !defined(HAL_NO_FLASH_SUPPORT) && !defined(HAL_NO_ROMFS_SUPPORT)
|
#if !defined(HAL_NO_FLASH_SUPPORT) && !defined(HAL_NO_ROMFS_SUPPORT)
|
||||||
@ -1662,8 +1659,8 @@ void AP_Periph_FW::can_start()
|
|||||||
canardInit(&dronecan.canard, (uint8_t *)dronecan.canard_memory_pool, sizeof(dronecan.canard_memory_pool),
|
canardInit(&dronecan.canard, (uint8_t *)dronecan.canard_memory_pool, sizeof(dronecan.canard_memory_pool),
|
||||||
onTransferReceived_trampoline, shouldAcceptTransfer_trampoline, this);
|
onTransferReceived_trampoline, shouldAcceptTransfer_trampoline, this);
|
||||||
|
|
||||||
if (PreferredNodeID != CANARD_BROADCAST_NODE_ID) {
|
if (user_set_node_id != CANARD_BROADCAST_NODE_ID) {
|
||||||
canardSetLocalNodeID(&dronecan.canard, PreferredNodeID);
|
canardSetLocalNodeID(&dronecan.canard, user_set_node_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user