altera.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /*
  2. * (C) Copyright 2003
  3. * Steven Scholz, imc Measurement & Control, steven.scholz@imc-berlin.de
  4. *
  5. * (C) Copyright 2002
  6. * Rich Ireland, Enterasys Networks, rireland@enterasys.com.
  7. *
  8. * SPDX-License-Identifier: GPL-2.0+
  9. */
  10. /*
  11. * Altera FPGA support
  12. */
  13. #include <common.h>
  14. #include <errno.h>
  15. #include <ACEX1K.h>
  16. #include <stratixII.h>
  17. /* Define FPGA_DEBUG to 1 to get debug printf's */
  18. #define FPGA_DEBUG 0
  19. static const struct altera_fpga {
  20. enum altera_family family;
  21. const char *name;
  22. int (*load)(Altera_desc *, const void *, size_t);
  23. int (*dump)(Altera_desc *, const void *, size_t);
  24. int (*info)(Altera_desc *);
  25. } altera_fpga[] = {
  26. #if defined(CONFIG_FPGA_ACEX1K)
  27. { Altera_ACEX1K, "ACEX1K", ACEX1K_load, ACEX1K_dump, ACEX1K_info },
  28. { Altera_CYC2, "ACEX1K", ACEX1K_load, ACEX1K_dump, ACEX1K_info },
  29. #elif defined(CONFIG_FPGA_CYCLON2)
  30. { Altera_ACEX1K, "CycloneII", CYC2_load, CYC2_dump, CYC2_info },
  31. { Altera_CYC2, "CycloneII", CYC2_load, CYC2_dump, CYC2_info },
  32. #endif
  33. #if defined(CONFIG_FPGA_STRATIX_II)
  34. { Altera_StratixII, "StratixII", StratixII_load,
  35. StratixII_dump, StratixII_info },
  36. #endif
  37. #if defined(CONFIG_FPGA_STRATIX_V)
  38. { Altera_StratixV, "StratixV", stratixv_load, NULL, NULL },
  39. #endif
  40. #if defined(CONFIG_FPGA_SOCFPGA)
  41. { Altera_SoCFPGA, "SoC FPGA", socfpga_load, NULL, NULL },
  42. #endif
  43. };
  44. static int altera_validate(Altera_desc *desc, const char *fn)
  45. {
  46. if (!desc) {
  47. printf("%s: NULL descriptor!\n", fn);
  48. return -EINVAL;
  49. }
  50. if ((desc->family < min_altera_type) ||
  51. (desc->family > max_altera_type)) {
  52. printf("%s: Invalid family type, %d\n", fn, desc->family);
  53. return -EINVAL;
  54. }
  55. if ((desc->iface < min_altera_iface_type) ||
  56. (desc->iface > max_altera_iface_type)) {
  57. printf("%s: Invalid Interface type, %d\n", fn, desc->iface);
  58. return -EINVAL;
  59. }
  60. if (!desc->size) {
  61. printf("%s: NULL part size\n", fn);
  62. return -EINVAL;
  63. }
  64. return 0;
  65. }
  66. static const struct altera_fpga *
  67. altera_desc_to_fpga(Altera_desc *desc, const char *fn)
  68. {
  69. int i;
  70. if (altera_validate(desc, fn)) {
  71. printf("%s: Invalid device descriptor\n", fn);
  72. return NULL;
  73. }
  74. for (i = 0; i < ARRAY_SIZE(altera_fpga); i++) {
  75. if (desc->family == altera_fpga[i].family)
  76. break;
  77. }
  78. if (i == ARRAY_SIZE(altera_fpga)) {
  79. printf("%s: Unsupported family type, %d\n", fn, desc->family);
  80. return NULL;
  81. }
  82. return &altera_fpga[i];
  83. }
  84. int altera_load(Altera_desc *desc, const void *buf, size_t bsize)
  85. {
  86. const struct altera_fpga *fpga = altera_desc_to_fpga(desc, __func__);
  87. if (!fpga)
  88. return FPGA_FAIL;
  89. debug_cond(FPGA_DEBUG, "%s: Launching the %s Loader...\n",
  90. __func__, fpga->name);
  91. if (fpga->load)
  92. return fpga->load(desc, buf, bsize);
  93. return 0;
  94. }
  95. int altera_dump(Altera_desc *desc, const void *buf, size_t bsize)
  96. {
  97. const struct altera_fpga *fpga = altera_desc_to_fpga(desc, __func__);
  98. if (!fpga)
  99. return FPGA_FAIL;
  100. debug_cond(FPGA_DEBUG, "%s: Launching the %s Reader...\n",
  101. __func__, fpga->name);
  102. if (fpga->dump)
  103. return fpga->dump(desc, buf, bsize);
  104. return 0;
  105. }
  106. int altera_info(Altera_desc *desc)
  107. {
  108. const struct altera_fpga *fpga = altera_desc_to_fpga(desc, __func__);
  109. if (!fpga)
  110. return FPGA_FAIL;
  111. printf("Family: \t%s\n", fpga->name);
  112. printf("Interface type:\t");
  113. switch (desc->iface) {
  114. case passive_serial:
  115. printf("Passive Serial (PS)\n");
  116. break;
  117. case passive_parallel_synchronous:
  118. printf("Passive Parallel Synchronous (PPS)\n");
  119. break;
  120. case passive_parallel_asynchronous:
  121. printf("Passive Parallel Asynchronous (PPA)\n");
  122. break;
  123. case passive_serial_asynchronous:
  124. printf("Passive Serial Asynchronous (PSA)\n");
  125. break;
  126. case altera_jtag_mode: /* Not used */
  127. printf("JTAG Mode\n");
  128. break;
  129. case fast_passive_parallel:
  130. printf("Fast Passive Parallel (FPP)\n");
  131. break;
  132. case fast_passive_parallel_security:
  133. printf("Fast Passive Parallel with Security (FPPS)\n");
  134. break;
  135. /* Add new interface types here */
  136. default:
  137. printf("Unsupported interface type, %d\n", desc->iface);
  138. }
  139. printf("Device Size: \t%zd bytes\n"
  140. "Cookie: \t0x%x (%d)\n",
  141. desc->size, desc->cookie, desc->cookie);
  142. if (desc->iface_fns) {
  143. printf("Device Function Table @ 0x%p\n", desc->iface_fns);
  144. if (fpga->info)
  145. fpga->info(desc);
  146. } else {
  147. printf("No Device Function Table.\n");
  148. }
  149. return FPGA_SUCCESS;
  150. }