Blame view

emulateur/epsilon-nofrendo/ion/src/device/regs/nvic.h 1.08 KB
6663b6c9   adorian   projet complet av...
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
  #ifndef REGS_NVIC_H
  #define REGS_NVIC_H
  
  #include "register.h"
  
  // http://www.st.com/content/ccc/resource/technical/document/programming_manual/6c/3a/cb/e7/e4/ea/44/9b/DM00046982.pdf/files/DM00046982.pdf/jcr:content/translations/en.DM00046982.pdf
  class NVIC {
  public:
    class MaskRegister : Register32 {
    public:
      bool get(int index) { return (bool)getBitRange(index, index); }
      void set(int index, bool state) volatile { setBitRange(index, index, state); }
    };
  
    class NVIC_ISER0 : public MaskRegister { };
    class NVIC_ISER1 : public MaskRegister { };
    class NVIC_ISER2 : public MaskRegister { };
    class NVIC_ICER0 : public MaskRegister { };
    class NVIC_ICER1 : public MaskRegister { };
    class NVIC_ICER2 : public MaskRegister { };
  
    constexpr NVIC() {};
    REGS_REGISTER_AT(NVIC_ISER0, 0x00);
    REGS_REGISTER_AT(NVIC_ISER1, 0x04);
    REGS_REGISTER_AT(NVIC_ISER2, 0x08);
    REGS_REGISTER_AT(NVIC_ICER0, 0x80);
    REGS_REGISTER_AT(NVIC_ICER1, 0x84);
    REGS_REGISTER_AT(NVIC_ICER2, 0x88);
  private:
    constexpr uint32_t Base() const {
      return 0xE000E100;
    }
  };
  
  constexpr NVIC NVIC;
  
  #endif