lp5562_reg.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. #pragma once
  2. #if BITS_BIG_ENDIAN == 1
  3. #error Bit structures defined in this file is not portable to BE
  4. #endif
  5. #define LP5562_ADDRESS 0x60
  6. #define LP5562_I2C_TIMEOUT 50
  7. typedef enum {
  8. EngExecHold = 0b00,
  9. EngExecStep = 0b01,
  10. EngExecRun = 0b10,
  11. EngExecPC = 0b11,
  12. } EngExec;
  13. typedef struct {
  14. EngExec ENG3_EXEC : 2;
  15. EngExec ENG2_EXEC : 2;
  16. EngExec ENG1_EXEC : 2;
  17. bool CHIP_EN : 1;
  18. bool LOG_EN : 1;
  19. } Reg00_Enable;
  20. typedef enum {
  21. EngModeDisable = 0b00,
  22. EngModeLoad = 0b01,
  23. EngModeRun = 0b10,
  24. EngModeDirect = 0b11,
  25. } EngMode;
  26. typedef struct {
  27. EngMode ENG3_MODE : 2;
  28. EngMode ENG2_MODE : 2;
  29. EngMode ENG1_MODE : 2;
  30. uint8_t reserved : 2;
  31. } Reg01_OpMode;
  32. typedef struct {
  33. bool INT_CLK_EN : 1;
  34. bool CLK_DET_EN : 1;
  35. uint8_t reserved0 : 3;
  36. bool PS_EN : 1;
  37. bool PWM_HF : 1;
  38. uint8_t reserved1 : 1;
  39. } Reg08_Config;
  40. typedef struct {
  41. uint8_t pc : 3;
  42. uint8_t reserved : 5;
  43. } Reg09_Engine1PC;
  44. typedef struct {
  45. uint8_t pc : 3;
  46. uint8_t reserved : 5;
  47. } Reg0A_Engine2PC;
  48. typedef struct {
  49. uint8_t pc : 3;
  50. uint8_t reserved : 5;
  51. } Reg0B_Engine3PC;
  52. typedef struct {
  53. bool ENG3_INT : 1;
  54. bool ENG2_INT : 1;
  55. bool ENG1_INT : 1;
  56. bool EXT_CLK_USED : 1;
  57. uint8_t reserved : 5;
  58. } Reg0C_Status;
  59. typedef struct {
  60. uint8_t value;
  61. } Reg0D_Reset;
  62. typedef enum {
  63. EngSelectI2C = 0b00,
  64. EngSelectEngine1 = 0b01,
  65. EngSelectEngine2 = 0b10,
  66. EngSelectEngine3 = 0b11,
  67. } EngSelect;
  68. typedef struct {
  69. EngSelect blue : 2;
  70. EngSelect green : 2;
  71. EngSelect red : 2;
  72. EngSelect white : 2;
  73. } Reg70_LedMap;