summaryrefslogtreecommitdiff
path: root/src/drivers/SpiNorFlash.h
blob: 98267c0933f03b75358afa304568f135d39b4413 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#pragma once
#include <cstddef>

namespace Pinetime {
  namespace Drivers {
    class Spi;
    class SpiNorFlash {
      public:
        explicit SpiNorFlash(Spi& spi);
        SpiNorFlash(const SpiNorFlash&) = delete;
        SpiNorFlash& operator=(const SpiNorFlash&) = delete;
        SpiNorFlash(SpiNorFlash&&) = delete;
        SpiNorFlash& operator=(SpiNorFlash&&) = delete;

        typedef struct __attribute__((packed)) {
          uint8_t manufacturer = 0;
          uint8_t type = 0;
          uint8_t density = 0;
        } Identification;

        Identification ReadIdentificaion();
        uint8_t ReadStatusRegister();
        bool WriteInProgress();
        bool WriteEnabled();
        uint8_t ReadConfigurationRegister();
        void Read(uint32_t address, uint8_t* buffer, size_t size);
        void Write(uint32_t address, const uint8_t *buffer, size_t size);
        void WriteEnable();
        void SectorErase(uint32_t sectorAddress);
        uint8_t ReadSecurityRegister();
        bool ProgramFailed();
        bool EraseFailed();


        void Init();
        void Uninit();


        void Sleep();
        void Wakeup();
      private:
        enum class Commands : uint8_t {
            PageProgram = 0x02,
            Read = 0x03,
            ReadStatusRegister = 0x05,
            WriteEnable = 0x06,
            ReadConfigurationRegister = 0x15,
            SectorErase = 0x20,
            ReadSecurityRegister = 0x2B,
            ReadIdentification = 0x9F,
        };
        static constexpr uint16_t pageSize = 256;

        Spi& spi;

    };
  }
}