From ac2c25539bf437f99c2ec4f3719604578c7f5ed4 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Fri, 4 Nov 2016 20:23:54 +1100 Subject: [PATCH] AP_InertialSensor: implement device IDs for AuxilaryBus --- libraries/AP_InertialSensor/AuxiliaryBus.cpp | 3 ++- libraries/AP_InertialSensor/AuxiliaryBus.h | 13 ++++++++++++- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/libraries/AP_InertialSensor/AuxiliaryBus.cpp b/libraries/AP_InertialSensor/AuxiliaryBus.cpp index a041550f58..39f92be2c8 100644 --- a/libraries/AP_InertialSensor/AuxiliaryBus.cpp +++ b/libraries/AP_InertialSensor/AuxiliaryBus.cpp @@ -16,9 +16,10 @@ AuxiliaryBusSlave::~AuxiliaryBusSlave() { } -AuxiliaryBus::AuxiliaryBus(AP_InertialSensor_Backend &backend, uint8_t max_slaves) +AuxiliaryBus::AuxiliaryBus(AP_InertialSensor_Backend &backend, uint8_t max_slaves, uint32_t devid) : _max_slaves(max_slaves) , _ins_backend(backend) + , _devid(devid) { _slaves = (AuxiliaryBusSlave**) calloc(max_slaves, sizeof(AuxiliaryBusSlave*)); } diff --git a/libraries/AP_InertialSensor/AuxiliaryBus.h b/libraries/AP_InertialSensor/AuxiliaryBus.h index 106a16964e..318ff15723 100644 --- a/libraries/AP_InertialSensor/AuxiliaryBus.h +++ b/libraries/AP_InertialSensor/AuxiliaryBus.h @@ -117,9 +117,19 @@ public: */ virtual AP_HAL::Semaphore *get_semaphore() = 0; + // set device type within a device class + void set_device_type(uint8_t devtype) { + _devid = AP_HAL::Device::change_bus_id(_devid, devtype); + } + + // return 24 bit bus identifier + uint32_t get_bus_id(void) const { + return _devid; + } + protected: /* Only AP_InertialSensor_Backend is able to create a bus */ - AuxiliaryBus(AP_InertialSensor_Backend &backend, uint8_t max_slaves); + AuxiliaryBus(AP_InertialSensor_Backend &backend, uint8_t max_slaves, uint32_t devid); virtual ~AuxiliaryBus(); virtual AuxiliaryBusSlave *_instantiate_slave(uint8_t addr, uint8_t instance) = 0; @@ -130,4 +140,5 @@ protected: const uint8_t _max_slaves; AuxiliaryBusSlave **_slaves; AP_InertialSensor_Backend &_ins_backend; + uint32_t _devid; };