2021-05-29 16:47:40 -03:00
|
|
|
/*
|
|
|
|
* This file is free software: you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License as published by the
|
|
|
|
* Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This file is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
* See the GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* Code by
|
|
|
|
* Andy Piper
|
|
|
|
* Siddharth Bharat Purohit, Cubepilot Pty. Ltd.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <inttypes.h>
|
|
|
|
#include <AP_HAL/HAL.h>
|
2022-08-17 10:15:32 -03:00
|
|
|
#include <AP_HAL/WSPIDevice.h>
|
2021-05-29 16:47:40 -03:00
|
|
|
#include "AP_HAL_ChibiOS.h"
|
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
#if HAL_USE_WSPI == TRUE && defined(HAL_WSPI_DEVICE_LIST)
|
2021-05-29 16:47:40 -03:00
|
|
|
|
2021-07-01 03:29:08 -03:00
|
|
|
#if !defined(HAL_BOOTLOADER_BUILD)
|
2021-05-29 16:47:40 -03:00
|
|
|
#include "Semaphores.h"
|
2021-07-01 03:29:08 -03:00
|
|
|
#endif
|
2022-03-27 15:07:19 -03:00
|
|
|
#include "hwdef/common/stm32_util.h"
|
2021-07-01 03:29:08 -03:00
|
|
|
|
2021-05-29 16:47:40 -03:00
|
|
|
#include "Scheduler.h"
|
|
|
|
#include "Device.h"
|
|
|
|
|
|
|
|
namespace ChibiOS
|
|
|
|
{
|
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
struct WSPIDesc {
|
|
|
|
WSPIDesc(const char *_name, uint8_t _bus,
|
2021-05-29 16:47:40 -03:00
|
|
|
uint32_t _mode, uint32_t _speed,
|
|
|
|
uint8_t _size_pow2, uint8_t _ncs_clk_shift)
|
|
|
|
: name(_name), bus(_bus), mode(_mode), speed(_speed),
|
|
|
|
size_pow2(_size_pow2), ncs_clk_delay(_ncs_clk_shift)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
const char *name; // name of the device
|
2022-08-17 10:15:32 -03:00
|
|
|
uint8_t bus; // WSPI bus being used
|
2021-05-29 16:47:40 -03:00
|
|
|
uint8_t device; // device id
|
|
|
|
uint32_t mode; // clock mode
|
|
|
|
uint32_t speed; // clock speed
|
|
|
|
uint8_t size_pow2; // size as power of 2
|
|
|
|
uint8_t ncs_clk_delay; // number of clk cycles to wait while transitioning NCS
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
class WSPIBus : public DeviceBus
|
2021-05-29 16:47:40 -03:00
|
|
|
{
|
|
|
|
public:
|
2022-08-17 10:15:32 -03:00
|
|
|
WSPIBus(uint8_t _bus) :
|
2021-05-29 16:47:40 -03:00
|
|
|
DeviceBus(APM_SPI_PRIORITY, true),
|
|
|
|
bus(_bus) {}
|
|
|
|
|
|
|
|
uint8_t bus;
|
|
|
|
WSPIConfig wspicfg;
|
2022-08-17 10:15:32 -03:00
|
|
|
bool wspi_started;
|
2021-05-29 16:47:40 -03:00
|
|
|
};
|
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
class WSPIDevice : public AP_HAL::WSPIDevice
|
2021-05-29 16:47:40 -03:00
|
|
|
{
|
|
|
|
public:
|
2022-08-17 10:15:32 -03:00
|
|
|
static WSPIDevice *from(AP_HAL::WSPIDevice *dev)
|
2021-05-29 16:47:40 -03:00
|
|
|
{
|
2022-08-17 10:15:32 -03:00
|
|
|
return static_cast<WSPIDevice*>(dev);
|
2021-05-29 16:47:40 -03:00
|
|
|
}
|
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
WSPIDevice(WSPIBus &_bus, WSPIDesc &_device_desc) :
|
2021-05-29 16:47:40 -03:00
|
|
|
bus(_bus),
|
|
|
|
device_desc(_device_desc)
|
|
|
|
{}
|
|
|
|
|
|
|
|
bool set_speed(Speed speed) override
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
PeriodicHandle register_periodic_callback(uint32_t period_usec, PeriodicCb) override
|
|
|
|
{
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
bool adjust_periodic_callback(PeriodicHandle h, uint32_t period_usec) override
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* See AP_HAL::Device::transfer() */
|
|
|
|
bool transfer(const uint8_t *send, uint32_t send_len,
|
|
|
|
uint8_t *recv, uint32_t recv_len) override;
|
|
|
|
|
|
|
|
void set_cmd_header(const CommandHeader& cmd_hdr) override;
|
|
|
|
|
|
|
|
AP_HAL::Semaphore* get_semaphore() override
|
|
|
|
{
|
2021-07-01 03:29:08 -03:00
|
|
|
#if !defined(HAL_BOOTLOADER_BUILD)
|
2021-05-29 16:47:40 -03:00
|
|
|
// if asking for invalid bus number use bus 0 semaphore
|
|
|
|
return &bus.semaphore;
|
2021-07-01 03:29:08 -03:00
|
|
|
#else
|
|
|
|
return nullptr;
|
|
|
|
#endif
|
2021-05-29 16:47:40 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
bool acquire_bus(bool acquire);
|
|
|
|
|
2021-06-08 04:43:55 -03:00
|
|
|
// Enters Memory mapped or eXecution In Place or 0-4-4 mode
|
|
|
|
bool enter_xip_mode(void** map_ptr) override;
|
|
|
|
bool exit_xip_mode() override;
|
|
|
|
|
2021-05-29 16:47:40 -03:00
|
|
|
private:
|
2022-08-17 10:15:32 -03:00
|
|
|
WSPIBus &bus;
|
|
|
|
WSPIDesc &device_desc;
|
2021-06-08 04:43:55 -03:00
|
|
|
wspi_command_t mode;
|
2021-05-29 16:47:40 -03:00
|
|
|
};
|
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
class WSPIDeviceManager : public AP_HAL::WSPIDeviceManager
|
2021-05-29 16:47:40 -03:00
|
|
|
{
|
|
|
|
public:
|
2022-08-17 10:15:32 -03:00
|
|
|
friend class WSPIDevice;
|
2021-05-29 16:47:40 -03:00
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
static WSPIDeviceManager *from(AP_HAL::WSPIDeviceManager *wspi_mgr)
|
2021-05-29 16:47:40 -03:00
|
|
|
{
|
2022-08-17 10:15:32 -03:00
|
|
|
return static_cast<WSPIDeviceManager*>(wspi_mgr);
|
2021-05-29 16:47:40 -03:00
|
|
|
}
|
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
AP_HAL::OwnPtr<AP_HAL::WSPIDevice> get_device(const char *name) override;
|
2021-05-29 16:47:40 -03:00
|
|
|
private:
|
2022-08-17 10:15:32 -03:00
|
|
|
static WSPIDesc device_table[];
|
|
|
|
WSPIBus *buses;
|
2021-05-29 16:47:40 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2022-08-17 10:15:32 -03:00
|
|
|
#endif // #if HAL_USE_WSPI == TRUE && defined(HAL_WSPI_DEVICE_LIST)
|