/* driver for RAMTRON FRAM persistent memory devices */ #pragma once #include <AP_Common/AP_Common.h> #include <AP_HAL/AP_HAL.h> class AP_RAMTRON { public: // initialise the driver // this will retry RAMTRON_RETRIES times until successful bool init(void); // get size in bytes uint32_t get_size(void) const { return (id == UINT8_MAX) ? 0 : ramtron_ids[id].size_kbyte * 1024UL; } // read from device // this will retry RAMTRON_RETRIES times until two successive reads return the same data bool read(uint32_t offset, uint8_t * const buf, uint32_t size); // write to device bool write(uint32_t offset, uint8_t const * const buf, uint32_t size); private: AP_HAL::OwnPtr<AP_HAL::SPIDevice> dev; enum class RDID_type :uint8_t { Cypress, Fujitsu, Petabytes }; struct ramtron_id { uint8_t id1; uint8_t id2; uint16_t size_kbyte; uint8_t addrlen; RDID_type rdid_type; }; static const struct ramtron_id ramtron_ids[]; uint8_t id = UINT8_MAX; // perform a single device initialisation bool _init(void); // perform a single device read bool _read(uint32_t offset, uint8_t * const buf, uint32_t size); void send_offset(uint8_t cmd, uint32_t offset) const; };