tdx-cfg-block.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. /* SPDX-License-Identifier: GPL-2.0+ */
  2. /*
  3. * Copyright (c) 2016-2020 Toradex
  4. */
  5. #ifndef _TDX_CFG_BLOCK_H
  6. #define _TDX_CFG_BLOCK_H
  7. #include "tdx-common.h"
  8. struct toradex_hw {
  9. u16 ver_major;
  10. u16 ver_minor;
  11. u16 ver_assembly;
  12. u16 prodid;
  13. };
  14. struct toradex_eth_addr {
  15. u32 oui:24;
  16. u32 nic:24;
  17. } __attribute__((__packed__));
  18. struct toradex_som {
  19. const char *name;
  20. int is_enabled;
  21. };
  22. enum {
  23. COLIBRI_PXA270_V1_312MHZ = 1,
  24. COLIBRI_PXA270_V1_520MHZ,
  25. COLIBRI_PXA320,
  26. COLIBRI_PXA300,
  27. COLIBRI_PXA310, /* 5 */
  28. COLIBRI_PXA320_IT,
  29. COLIBRI_PXA300_XT,
  30. COLIBRI_PXA270_312MHZ,
  31. COLIBRI_PXA270_520MHZ,
  32. COLIBRI_VF50, /* 10 */
  33. COLIBRI_VF61,
  34. COLIBRI_VF61_IT,
  35. COLIBRI_VF50_IT,
  36. COLIBRI_IMX6S,
  37. COLIBRI_IMX6DL, /* 15 */
  38. COLIBRI_IMX6S_IT,
  39. COLIBRI_IMX6DL_IT,
  40. /* 18 */
  41. /* 19 */
  42. COLIBRI_T20_256MB = 20,
  43. COLIBRI_T20_512MB,
  44. COLIBRI_T20_512MB_IT,
  45. COLIBRI_T30,
  46. COLIBRI_T20_256MB_IT,
  47. APALIS_T30_2GB, /* 25 */
  48. APALIS_T30_1GB,
  49. APALIS_IMX6Q,
  50. APALIS_IMX6Q_IT,
  51. APALIS_IMX6D,
  52. COLIBRI_T30_IT, /* 30 */
  53. APALIS_T30_IT,
  54. COLIBRI_IMX7S,
  55. COLIBRI_IMX7D,
  56. APALIS_TK1_2GB,
  57. APALIS_IMX6D_IT, /* 35 */
  58. COLIBRI_IMX6ULL,
  59. APALIS_IMX8QM_WIFI_BT_IT,
  60. COLIBRI_IMX8QXP_WIFI_BT_IT,
  61. COLIBRI_IMX7D_EMMC,
  62. COLIBRI_IMX6ULL_WIFI_BT_IT, /* 40 */
  63. COLIBRI_IMX7D_EPDC,
  64. APALIS_TK1_4GB,
  65. COLIBRI_T20_512MB_IT_SETEK,
  66. COLIBRI_IMX6ULL_IT,
  67. COLIBRI_IMX6ULL_WIFI_BT, /* 45 */
  68. APALIS_IMX8QXP_WIFI_BT_IT,
  69. APALIS_IMX8QM_IT,
  70. APALIS_IMX8QP_WIFI_BT,
  71. APALIS_IMX8QP,
  72. COLIBRI_IMX8QXP_IT, /* 50 */
  73. COLIBRI_IMX8DX_WIFI_BT,
  74. COLIBRI_IMX8DX,
  75. APALIS_IMX8QXP,
  76. APALIS_IMX8DXP,
  77. VERDIN_IMX8MMQ_WIFI_BT_IT, /* 55 */
  78. VERDIN_IMX8MNQ_WIFI_BT,
  79. VERDIN_IMX8MMDL,
  80. VERDIN_IMX8MPQ_WIFI_BT_IT,
  81. VERDIN_IMX8MMQ_IT,
  82. VERDIN_IMX8MMDL_WIFI_BT_IT, /* 60 */
  83. VERDIN_IMX8MPQ,
  84. COLIBRI_IMX6ULL_IT_EMMC,
  85. VERDIN_IMX8MPQ_IT,
  86. VERDIN_IMX8MPQ_2GB_WIFI_BT_IT,
  87. VERDIN_IMX8MPQL_IT, /* 65 */
  88. VERDIN_IMX8MPQ_8GB_WIFI_BT,
  89. APALIS_IMX8QM_8GB_WIFI_BT_IT,
  90. VERDIN_IMX8MMQ_WIFI_BT_IT_NO_CAN,
  91. VERDIN_AM62Q_WIFI_BT_IT,
  92. VERDIN_IMX8MPQ_8GB_WIFI_BT_IT, /* 70 */
  93. VERDIN_AM62S_512MB,
  94. VERDIN_AM62S_512MB_WIFI_BT_IT,
  95. VERDIN_AM62D_1G_ET,
  96. VERDIN_AM62D_1G_IT,
  97. VERDIN_AM62D_1G_WIFI_BT_IT, /* 75 */
  98. VERDIN_AM62Q_2G_WIFI_BT_IT,
  99. };
  100. enum {
  101. DAHLIA = 155,
  102. VERDIN_DEVELOPMENT_BOARD = 156,
  103. YAVIA = 173,
  104. };
  105. enum {
  106. VERDIN_DSI_TO_HDMI_ADAPTER = 157,
  107. VERDIN_DSI_TO_LVDS_ADAPTER = 159,
  108. };
  109. extern const struct toradex_som toradex_modules[];
  110. extern bool valid_cfgblock;
  111. extern struct toradex_hw tdx_hw_tag;
  112. extern struct toradex_hw tdx_car_hw_tag;
  113. extern struct toradex_eth_addr tdx_eth_addr;
  114. extern u32 tdx_serial;
  115. extern u32 tdx_car_serial;
  116. int read_tdx_cfg_block(void);
  117. int read_tdx_cfg_block_carrier(void);
  118. const char * const get_toradex_carrier_boards(int pid4);
  119. const char * const get_toradex_display_adapters(int pid4);
  120. int try_migrate_tdx_cfg_block_carrier(void);
  121. void get_mac_from_serial(u32 tdx_serial, struct toradex_eth_addr *eth_addr);
  122. #endif /* _TDX_CFG_BLOCK_H */