mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 18:08:30 -04:00
AP_CANSensor: create a separate register driver method
This commit is contained in:
parent
917280de1b
commit
1bac7283ab
@ -30,20 +30,26 @@ extern const AP_HAL::HAL& hal;
|
||||
#define debug_can(level_debug, fmt, args...)
|
||||
#endif
|
||||
|
||||
CANSensor::CANSensor(const char *driver_name, AP_CANManager::Driver_Type dtype, uint16_t stack_size) :
|
||||
CANSensor::CANSensor(const char *driver_name, uint16_t stack_size) :
|
||||
_driver_name(driver_name),
|
||||
_stack_size(stack_size)
|
||||
{}
|
||||
|
||||
|
||||
void CANSensor::register_driver(AP_CANManager::Driver_Type dtype)
|
||||
{
|
||||
#if HAL_CANMANAGER_ENABLED
|
||||
if (!AP::can().register_driver(dtype, this)) {
|
||||
debug_can(AP_CANManager::LOG_ERROR, "Failed to register CANSensor %s", driver_name);
|
||||
debug_can(AP_CANManager::LOG_ERROR, "Failed to register CANSensor %s", _driver_name);
|
||||
} else {
|
||||
debug_can(AP_CANManager::LOG_INFO, "%s: constructed", driver_name);
|
||||
debug_can(AP_CANManager::LOG_INFO, "%s: constructed", _driver_name);
|
||||
}
|
||||
#elif defined(HAL_BUILD_AP_PERIPH)
|
||||
register_driver_periph(dtype);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
#ifdef HAL_BUILD_AP_PERIPH
|
||||
CANSensor::CANSensor_Periph CANSensor::_periph[HAL_NUM_CAN_IFACES];
|
||||
|
||||
|
@ -24,8 +24,8 @@
|
||||
|
||||
class CANSensor : public AP_CANDriver {
|
||||
public:
|
||||
CANSensor(const char *driver_name, AP_CANManager::Driver_Type dtype, uint16_t stack_size=2048);
|
||||
|
||||
CANSensor(const char *driver_name, uint16_t stack_size=2048);
|
||||
|
||||
/* Do not allow copies */
|
||||
CANSensor(const CANSensor &other) = delete;
|
||||
CANSensor &operator=(const CANSensor&) = delete;
|
||||
@ -48,6 +48,9 @@ public:
|
||||
}
|
||||
#endif
|
||||
|
||||
protected:
|
||||
void register_driver(AP_CANManager::Driver_Type dtype);
|
||||
|
||||
private:
|
||||
void loop();
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user