altera.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  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_SOCFPGA)
  38. { Altera_SoCFPGA, "SoC FPGA", socfpga_load, NULL, NULL },
  39. #endif
  40. };
  41. static int altera_validate(Altera_desc *desc, const char *fn)
  42. {
  43. if (!desc) {
  44. printf("%s: NULL descriptor!\n", fn);
  45. return -EINVAL;
  46. }
  47. if ((desc->family < min_altera_type) ||
  48. (desc->family > max_altera_type)) {
  49. printf("%s: Invalid family type, %d\n", fn, desc->family);
  50. return -EINVAL;
  51. }
  52. if ((desc->iface < min_altera_iface_type) ||
  53. (desc->iface > max_altera_iface_type)) {
  54. printf("%s: Invalid Interface type, %d\n", fn, desc->iface);
  55. return -EINVAL;
  56. }
  57. if (!desc->size) {
  58. printf("%s: NULL part size\n", fn);
  59. return -EINVAL;
  60. }
  61. return 0;
  62. }
  63. static const struct altera_fpga *
  64. altera_desc_to_fpga(Altera_desc *desc, const char *fn)
  65. {
  66. int i;
  67. if (altera_validate(desc, fn)) {
  68. printf("%s: Invalid device descriptor\n", fn);
  69. return NULL;
  70. }
  71. for (i = 0; i < ARRAY_SIZE(altera_fpga); i++) {
  72. if (desc->family == altera_fpga[i].family)
  73. break;
  74. }
  75. if (i == ARRAY_SIZE(altera_fpga)) {
  76. printf("%s: Unsupported family type, %d\n", fn, desc->family);
  77. return NULL;
  78. }
  79. return &altera_fpga[i];
  80. }
  81. int altera_load(Altera_desc *desc, const void *buf, size_t bsize)
  82. {
  83. const struct altera_fpga *fpga = altera_desc_to_fpga(desc, __func__);
  84. if (!fpga)
  85. return FPGA_FAIL;
  86. debug_cond(FPGA_DEBUG, "%s: Launching the %s Loader...\n",
  87. __func__, fpga->name);
  88. if (fpga->load)
  89. return fpga->load(desc, buf, bsize);
  90. return 0;
  91. }
  92. int altera_dump(Altera_desc *desc, const void *buf, size_t bsize)
  93. {
  94. const struct altera_fpga *fpga = altera_desc_to_fpga(desc, __func__);
  95. if (!fpga)
  96. return FPGA_FAIL;
  97. debug_cond(FPGA_DEBUG, "%s: Launching the %s Reader...\n",
  98. __func__, fpga->name);
  99. if (fpga->dump)
  100. return fpga->dump(desc, buf, bsize);
  101. return 0;
  102. }
  103. int altera_info(Altera_desc *desc)
  104. {
  105. const struct altera_fpga *fpga = altera_desc_to_fpga(desc, __func__);
  106. if (!fpga)
  107. return FPGA_FAIL;
  108. printf("Family: \t%s\n", fpga->name);
  109. printf("Interface type:\t");
  110. switch (desc->iface) {
  111. case passive_serial:
  112. printf("Passive Serial (PS)\n");
  113. break;
  114. case passive_parallel_synchronous:
  115. printf("Passive Parallel Synchronous (PPS)\n");
  116. break;
  117. case passive_parallel_asynchronous:
  118. printf("Passive Parallel Asynchronous (PPA)\n");
  119. break;
  120. case passive_serial_asynchronous:
  121. printf("Passive Serial Asynchronous (PSA)\n");
  122. break;
  123. case altera_jtag_mode: /* Not used */
  124. printf("JTAG Mode\n");
  125. break;
  126. case fast_passive_parallel:
  127. printf("Fast Passive Parallel (FPP)\n");
  128. break;
  129. case fast_passive_parallel_security:
  130. printf("Fast Passive Parallel with Security (FPPS)\n");
  131. break;
  132. /* Add new interface types here */
  133. default:
  134. printf("Unsupported interface type, %d\n", desc->iface);
  135. }
  136. printf("Device Size: \t%zd bytes\n"
  137. "Cookie: \t0x%x (%d)\n",
  138. desc->size, desc->cookie, desc->cookie);
  139. if (desc->iface_fns) {
  140. printf("Device Function Table @ 0x%p\n", desc->iface_fns);
  141. if (fpga->info)
  142. fpga->info(desc);
  143. } else {
  144. printf("No Device Function Table.\n");
  145. }
  146. return FPGA_SUCCESS;
  147. }