tdx-common.c 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (c) 2016 Toradex, Inc.
  4. */
  5. #include <common.h>
  6. #include <env.h>
  7. #include <g_dnl.h>
  8. #include <init.h>
  9. #include <linux/libfdt.h>
  10. #ifdef CONFIG_VIDEO
  11. #include <bmp_logo.h>
  12. #include <dm.h>
  13. #include <splash.h>
  14. #include <video.h>
  15. #endif
  16. #include "tdx-cfg-block.h"
  17. #include <asm/setup.h>
  18. #include "tdx-common.h"
  19. #define SERIAL_STR_LEN 8
  20. #define MODULE_VER_STR_LEN 4 // V1.1
  21. #define MODULE_REV_STR_LEN 3 // [A-Z] or #[26-99]
  22. #ifdef CONFIG_TDX_CFG_BLOCK
  23. static char tdx_serial_str[SERIAL_STR_LEN + 1];
  24. static char tdx_board_rev_str[MODULE_VER_STR_LEN + MODULE_REV_STR_LEN + 1];
  25. #ifdef CONFIG_TDX_CFG_BLOCK_EXTRA
  26. static char tdx_car_serial_str[SERIAL_STR_LEN + 1];
  27. static char tdx_car_rev_str[MODULE_VER_STR_LEN + MODULE_REV_STR_LEN + 1];
  28. static const char *tdx_carrier_board_name;
  29. #endif
  30. #if defined(CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG)
  31. u32 get_board_revision(void)
  32. {
  33. /* Check validity */
  34. if (!tdx_hw_tag.ver_major)
  35. return 0;
  36. return ((tdx_hw_tag.ver_major & 0xff) << 8) |
  37. ((tdx_hw_tag.ver_minor & 0xf) << 4) |
  38. ((tdx_hw_tag.ver_assembly & 0xf) + 0xa);
  39. }
  40. #endif /* CONFIG_TDX_CFG_BLOCK */
  41. #ifdef CONFIG_SERIAL_TAG
  42. void get_board_serial(struct tag_serialnr *serialnr)
  43. {
  44. int array[8];
  45. unsigned int serial = tdx_serial;
  46. int i;
  47. serialnr->low = 0;
  48. serialnr->high = 0;
  49. /* Check validity */
  50. if (serial) {
  51. /*
  52. * Convert to Linux serial number format (hexadecimal coded
  53. * decimal)
  54. */
  55. i = 7;
  56. while (serial) {
  57. array[i--] = serial % 10;
  58. serial /= 10;
  59. }
  60. while (i >= 0)
  61. array[i--] = 0;
  62. serial = array[0];
  63. for (i = 1; i < 8; i++) {
  64. serial *= 16;
  65. serial += array[i];
  66. }
  67. serialnr->low = serial;
  68. }
  69. }
  70. #endif /* CONFIG_SERIAL_TAG */
  71. static const char *get_board_assembly(u16 ver_assembly)
  72. {
  73. static char ver_name[MODULE_REV_STR_LEN + 1];
  74. if (ver_assembly < 26) {
  75. ver_name[0] = (char)ver_assembly + 'A';
  76. ver_name[1] = '\0';
  77. } else {
  78. snprintf(ver_name, sizeof(ver_name),
  79. "#%u", ver_assembly);
  80. }
  81. return ver_name;
  82. }
  83. int show_board_info(void)
  84. {
  85. unsigned char ethaddr[6];
  86. if (read_tdx_cfg_block()) {
  87. printf("MISSING TORADEX CONFIG BLOCK\n");
  88. get_mac_from_serial(tdx_serial, &tdx_eth_addr);
  89. checkboard();
  90. } else {
  91. snprintf(tdx_serial_str, sizeof(tdx_serial_str),
  92. "%08u", tdx_serial);
  93. snprintf(tdx_board_rev_str, sizeof(tdx_board_rev_str),
  94. "V%1d.%1d%s",
  95. tdx_hw_tag.ver_major,
  96. tdx_hw_tag.ver_minor,
  97. get_board_assembly(tdx_hw_tag.ver_assembly));
  98. env_set("serial#", tdx_serial_str);
  99. printf("Model: Toradex %04d %s %s\n",
  100. tdx_hw_tag.prodid,
  101. toradex_modules[tdx_hw_tag.prodid].name,
  102. tdx_board_rev_str);
  103. printf("Serial#: %s\n", tdx_serial_str);
  104. #ifdef CONFIG_TDX_CFG_BLOCK_EXTRA
  105. if (read_tdx_cfg_block_carrier()) {
  106. printf("MISSING TORADEX CARRIER CONFIG BLOCKS\n");
  107. try_migrate_tdx_cfg_block_carrier();
  108. } else {
  109. tdx_carrier_board_name =
  110. get_toradex_carrier_boards(tdx_car_hw_tag.prodid);
  111. snprintf(tdx_car_serial_str, sizeof(tdx_car_serial_str),
  112. "%08u", tdx_car_serial);
  113. snprintf(tdx_car_rev_str, sizeof(tdx_car_rev_str),
  114. "V%1d.%1d%s",
  115. tdx_car_hw_tag.ver_major,
  116. tdx_car_hw_tag.ver_minor,
  117. get_board_assembly(tdx_car_hw_tag.ver_assembly));
  118. env_set("carrier_serial#", tdx_car_serial_str);
  119. printf("Carrier: Toradex %s %s, Serial# %s\n",
  120. tdx_carrier_board_name,
  121. tdx_car_rev_str,
  122. tdx_car_serial_str);
  123. }
  124. #endif
  125. }
  126. /*
  127. * Check if environment contains a valid MAC address,
  128. * set the one from config block if not
  129. */
  130. if (!eth_env_get_enetaddr("ethaddr", ethaddr))
  131. eth_env_set_enetaddr("ethaddr", (u8 *)&tdx_eth_addr);
  132. if (IS_ENABLED(CONFIG_TDX_CFG_BLOCK_2ND_ETHADDR) &&
  133. !eth_env_get_enetaddr("eth1addr", ethaddr)) {
  134. /*
  135. * Secondary MAC address is allocated from block
  136. * 0x100000 higher then the first MAC address
  137. */
  138. memcpy(ethaddr, &tdx_eth_addr, 6);
  139. ethaddr[3] += 0x10;
  140. eth_env_set_enetaddr("eth1addr", ethaddr);
  141. }
  142. return 0;
  143. }
  144. #ifdef CONFIG_TDX_CFG_BLOCK_USB_GADGET_PID
  145. int g_dnl_bind_fixup(struct usb_device_descriptor *dev, const char *name)
  146. {
  147. unsigned short usb_pid;
  148. usb_pid = TORADEX_USB_PRODUCT_NUM_OFFSET + tdx_hw_tag.prodid;
  149. put_unaligned(usb_pid, &dev->idProduct);
  150. return 0;
  151. }
  152. #endif
  153. #if defined(CONFIG_OF_LIBFDT)
  154. int ft_common_board_setup(void *blob, struct bd_info *bd)
  155. {
  156. if (tdx_serial) {
  157. fdt_setprop(blob, 0, "serial-number", tdx_serial_str,
  158. strlen(tdx_serial_str) + 1);
  159. }
  160. if (tdx_hw_tag.ver_major) {
  161. char prod_id[5];
  162. snprintf(prod_id, sizeof(prod_id), "%04u", tdx_hw_tag.prodid);
  163. fdt_setprop(blob, 0, "toradex,product-id", prod_id, 5);
  164. fdt_setprop(blob, 0, "toradex,board-rev", tdx_board_rev_str,
  165. strlen(tdx_board_rev_str) + 1);
  166. }
  167. return 0;
  168. }
  169. #endif
  170. #else /* CONFIG_TDX_CFG_BLOCK */
  171. #if defined(CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG)
  172. u32 get_board_revision(void)
  173. {
  174. return 0;
  175. }
  176. #endif /* CONFIG_REVISION_TAG */
  177. #ifdef CONFIG_SERIAL_TAG
  178. u32 get_board_serial(void)
  179. {
  180. return 0;
  181. }
  182. #endif /* CONFIG_SERIAL_TAG */
  183. int ft_common_board_setup(void *blob, struct bd_info *bd)
  184. {
  185. return 0;
  186. }
  187. #endif /* CONFIG_TDX_CFG_BLOCK */