qts-filter.sh 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. #!/bin/sh
  2. #
  3. # Process iocsr_config_*.[ch]
  4. # $1: SoC type
  5. # $2: Input handoff directory
  6. # $3: Input BSP Generated directory
  7. # $4: Output directory
  8. #
  9. process_iocsr_config() {
  10. soc="$1"
  11. in_qts_dir="$2"
  12. in_bsp_dir="$3"
  13. out_dir="$4"
  14. (
  15. cat << EOF
  16. /*
  17. * Altera SoCFPGA IOCSR configuration
  18. *
  19. * SPDX-License-Identifier: BSD-3-Clause
  20. */
  21. #ifndef __SOCFPGA_IOCSR_CONFIG_H__
  22. #define __SOCFPGA_IOCSR_CONFIG_H__
  23. EOF
  24. # Retrieve the scan chain lengths
  25. grep 'CONFIG_HPS_IOCSR_SCANCHAIN[0-9]\+_LENGTH' \
  26. ${in_bsp_dir}/generated/iocsr_config_${soc}.h | tr -d "()"
  27. echo ""
  28. # Retrieve the scan chain config and zap the ad-hoc length encoding
  29. sed -n '/^const/ !b; :next {/^const/ s/(.*)//;p;n;b next}' \
  30. ${in_bsp_dir}/generated/iocsr_config_${soc}.c
  31. cat << EOF
  32. #endif /* __SOCFPGA_IOCSR_CONFIG_H__ */
  33. EOF
  34. ) > "${out_dir}/iocsr_config.h"
  35. }
  36. #
  37. # Process pinmux_config_*.c (and ignore pinmux_config.h)
  38. # $1: SoC type
  39. # $2: Input directory
  40. # $3: Output directory
  41. #
  42. process_pinmux_config() {
  43. soc="$1"
  44. in_qts_dir="$2"
  45. in_bsp_dir="$3"
  46. out_dir="$4"
  47. (
  48. cat << EOF
  49. /*
  50. * Altera SoCFPGA PinMux configuration
  51. *
  52. * SPDX-License-Identifier: BSD-3-Clause
  53. */
  54. #ifndef __SOCFPGA_PINMUX_CONFIG_H__
  55. #define __SOCFPGA_PINMUX_CONFIG_H__
  56. EOF
  57. # Retrieve the pinmux config and zap the ad-hoc length encoding
  58. sed -n '/^unsigned/ !b; :next {/^unsigned/ {s/\[.*\]/[]/;s/unsigned long/const u8/};p;n;b next}' \
  59. ${in_bsp_dir}/generated/pinmux_config_${soc}.c
  60. cat << EOF
  61. #endif /* __SOCFPGA_PINMUX_CONFIG_H__ */
  62. EOF
  63. ) > "${out_dir}/pinmux_config.h"
  64. }
  65. #
  66. # Process pll_config.h
  67. # $1: SoC type (not used)
  68. # $2: Input directory
  69. # $3: Output directory
  70. #
  71. process_pll_config() {
  72. soc="$1"
  73. in_qts_dir="$2"
  74. in_bsp_dir="$3"
  75. out_dir="$4"
  76. (
  77. cat << EOF
  78. /*
  79. * Altera SoCFPGA Clock and PLL configuration
  80. *
  81. * SPDX-License-Identifier: BSD-3-Clause
  82. */
  83. #ifndef __SOCFPGA_PLL_CONFIG_H__
  84. #define __SOCFPGA_PLL_CONFIG_H__
  85. EOF
  86. # Retrieve the pll config and zap parenthesis
  87. sed -n '/CONFIG_HPS/ !b; :next {/CONFIG_HPS/ s/[()]//g;/endif/ b;p;n;b next}' \
  88. ${in_bsp_dir}/generated/pll_config.h
  89. cat << EOF
  90. #endif /* __SOCFPGA_PLL_CONFIG_H__ */
  91. EOF
  92. ) > "${out_dir}/pll_config.h"
  93. }
  94. #
  95. # Filter out only the macros which are actually used by the code
  96. #
  97. grep_sdram_config() {
  98. egrep "#define (CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_MEMTYPE|CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_MEMBL|CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_ADDRORDER|CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_ECCEN|CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_ECCCORREN|CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_REORDEREN|CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_STARVELIMIT|CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_DQSTRKEN|CONFIG_HPS_SDR_CTRLCFG_CTRLCFG_NODMPINS|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TCWL|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_AL|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TCL|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TRRD|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TFAW|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING1_TRFC|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TREFI|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TRCD|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TRP|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TWR|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING2_IF_TWTR|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TRTP|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TRAS|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TRC|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TMRD|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING3_TCCD|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING4_SELFRFSHEXIT|CONFIG_HPS_SDR_CTRLCFG_DRAMTIMING4_PWRDOWNEXIT|CONFIG_HPS_SDR_CTRLCFG_LOWPWRTIMING_AUTOPDCYCLES|CONFIG_HPS_SDR_CTRLCFG_LOWPWRTIMING_CLKDISABLECYCLES|CONFIG_HPS_SDR_CTRLCFG_DRAMODT_READ|CONFIG_HPS_SDR_CTRLCFG_DRAMODT_WRITE|CONFIG_HPS_SDR_CTRLCFG_DRAMADDRW_COLBITS|CONFIG_HPS_SDR_CTRLCFG_DRAMADDRW_ROWBITS|CONFIG_HPS_SDR_CTRLCFG_DRAMADDRW_BANKBITS|CONFIG_HPS_SDR_CTRLCFG_DRAMADDRW_CSBITS|CONFIG_HPS_SDR_CTRLCFG_DRAMIFWIDTH_IFWIDTH|CONFIG_HPS_SDR_CTRLCFG_DRAMDEVWIDTH_DEVWIDTH|CONFIG_HPS_SDR_CTRLCFG_DRAMINTR_INTREN|CONFIG_HPS_SDR_CTRLCFG_LOWPWREQ_SELFRFSHMASK|CONFIG_HPS_SDR_CTRLCFG_STATICCFG_MEMBL|CONFIG_HPS_SDR_CTRLCFG_STATICCFG_USEECCASDATA|CONFIG_HPS_SDR_CTRLCFG_CTRLWIDTH_CTRLWIDTH|CONFIG_HPS_SDR_CTRLCFG_CPORTWIDTH_CPORTWIDTH|CONFIG_HPS_SDR_CTRLCFG_CPORTWMAP_CPORTWMAP|CONFIG_HPS_SDR_CTRLCFG_CPORTRMAP_CPORTRMAP|CONFIG_HPS_SDR_CTRLCFG_RFIFOCMAP_RFIFOCMAP|CONFIG_HPS_SDR_CTRLCFG_WFIFOCMAP_WFIFOCMAP|CONFIG_HPS_SDR_CTRLCFG_CPORTRDWR_CPORTRDWR|CONFIG_HPS_SDR_CTRLCFG_PORTCFG_AUTOPCHEN|CONFIG_HPS_SDR_CTRLCFG_FPGAPORTRST|CONFIG_HPS_SDR_CTRLCFG_FIFOCFG_SYNCMODE|CONFIG_HPS_SDR_CTRLCFG_FIFOCFG_INCSYNC|CONFIG_HPS_SDR_CTRLCFG_MPPRIORITY_USERPRIORITY|CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_0_STATICWEIGHT_31_0|CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_1_STATICWEIGHT_49_32|CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_1_SUMOFWEIGHT_13_0|CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_2_SUMOFWEIGHT_45_14|CONFIG_HPS_SDR_CTRLCFG_MPWIEIGHT_3_SUMOFWEIGHT_63_46|CONFIG_HPS_SDR_CTRLCFG_PHYCTRL_PHYCTRL_0|CONFIG_HPS_SDR_CTRLCFG_MPPACING_0_THRESHOLD1_31_0|CONFIG_HPS_SDR_CTRLCFG_MPPACING_1_THRESHOLD1_59_32|CONFIG_HPS_SDR_CTRLCFG_MPPACING_1_THRESHOLD2_3_0|CONFIG_HPS_SDR_CTRLCFG_MPPACING_2_THRESHOLD2_35_4|CONFIG_HPS_SDR_CTRLCFG_MPPACING_3_THRESHOLD2_59_36|CONFIG_HPS_SDR_CTRLCFG_MPTHRESHOLDRST_0_THRESHOLDRSTCYCLES_31_0|CONFIG_HPS_SDR_CTRLCFG_MPTHRESHOLDRST_1_THRESHOLDRSTCYCLES_63_32|CONFIG_HPS_SDR_CTRLCFG_MPTHRESHOLDRST_2_THRESHOLDRSTCYCLES_79_64|RW_MGR_ACTIVATE_0_AND_1|RW_MGR_ACTIVATE_0_AND_1_WAIT1|RW_MGR_ACTIVATE_0_AND_1_WAIT2|RW_MGR_ACTIVATE_1|RW_MGR_CLEAR_DQS_ENABLE|RW_MGR_GUARANTEED_READ|RW_MGR_GUARANTEED_READ_CONT|RW_MGR_GUARANTEED_WRITE|RW_MGR_GUARANTEED_WRITE_WAIT0|RW_MGR_GUARANTEED_WRITE_WAIT1|RW_MGR_GUARANTEED_WRITE_WAIT2|RW_MGR_GUARANTEED_WRITE_WAIT3|RW_MGR_IDLE|RW_MGR_IDLE_LOOP1|RW_MGR_IDLE_LOOP2|RW_MGR_INIT_RESET_0_CKE_0|RW_MGR_INIT_RESET_1_CKE_0|RW_MGR_LFSR_WR_RD_BANK_0|RW_MGR_LFSR_WR_RD_BANK_0_DATA|RW_MGR_LFSR_WR_RD_BANK_0_DQS|RW_MGR_LFSR_WR_RD_BANK_0_NOP|RW_MGR_LFSR_WR_RD_BANK_0_WAIT|RW_MGR_LFSR_WR_RD_BANK_0_WL_1|RW_MGR_LFSR_WR_RD_DM_BANK_0|RW_MGR_LFSR_WR_RD_DM_BANK_0_DATA|RW_MGR_LFSR_WR_RD_DM_BANK_0_DQS|RW_MGR_LFSR_WR_RD_DM_BANK_0_NOP|RW_MGR_LFSR_WR_RD_DM_BANK_0_WAIT|RW_MGR_LFSR_WR_RD_DM_BANK_0_WL_1|RW_MGR_MRS0_DLL_RESET|RW_MGR_MRS0_DLL_RESET_MIRR|RW_MGR_MRS0_USER|RW_MGR_MRS0_USER_MIRR|RW_MGR_MRS1|RW_MGR_MRS1_MIRR|RW_MGR_MRS2|RW_MGR_MRS2_MIRR|RW_MGR_MRS3|RW_MGR_MRS3_MIRR|RW_MGR_PRECHARGE_ALL|RW_MGR_READ_B2B|RW_MGR_READ_B2B_WAIT1|RW_MGR_READ_B2B_WAIT2|RW_MGR_REFRESH_ALL|RW_MGR_RETURN|RW_MGR_SGLE_READ|RW_MGR_ZQCL|RW_MGR_TRUE_MEM_DATA_MASK_WIDTH|RW_MGR_MEM_ADDRESS_MIRRORING|RW_MGR_MEM_DATA_MASK_WIDTH|RW_MGR_MEM_DATA_WIDTH|RW_MGR_MEM_DQ_PER_READ_DQS|RW_MGR_MEM_DQ_PER_WRITE_DQS|RW_MGR_MEM_IF_READ_DQS_WIDTH|RW_MGR_MEM_IF_WRITE_DQS_WIDTH|RW_MGR_MEM_NUMBER_OF_CS_PER_DIMM|RW_MGR_MEM_NUMBER_OF_RANKS|RW_MGR_MEM_VIRTUAL_GROUPS_PER_READ_DQS|RW_MGR_MEM_VIRTUAL_GROUPS_PER_WRITE_DQS|IO_DELAY_PER_DCHAIN_TAP|IO_DELAY_PER_DQS_EN_DCHAIN_TAP|IO_DELAY_PER_OPA_TAP|IO_DLL_CHAIN_LENGTH|IO_DQDQS_OUT_PHASE_MAX|IO_DQS_EN_DELAY_MAX|IO_DQS_EN_DELAY_OFFSET|IO_DQS_EN_PHASE_MAX|IO_DQS_IN_DELAY_MAX|IO_DQS_IN_RESERVE|IO_DQS_OUT_RESERVE|IO_IO_IN_DELAY_MAX|IO_IO_OUT1_DELAY_MAX|IO_IO_OUT2_DELAY_MAX|IO_SHIFT_DQS_EN_WHEN_SHIFT_DQS|AFI_RATE_RATIO|CALIB_LFIFO_OFFSET|CALIB_VFIFO_OFFSET|ENABLE_SUPER_QUICK_CALIBRATION|MAX_LATENCY_COUNT_WIDTH|READ_VALID_FIFO_SIZE|REG_FILE_INIT_SEQ_SIGNATURE|TINIT_CNTR0_VAL|TINIT_CNTR1_VAL|TINIT_CNTR2_VAL|TRESET_CNTR0_VAL|TRESET_CNTR1_VAL|TRESET_CNTR2_VAL)[[:space:]]"
  99. }
  100. #
  101. # Process sdram_config.h, sequencer_auto*h and sequencer_defines.h
  102. # $1: SoC type (not used)
  103. # $2: Input directory
  104. # $3: Output directory
  105. #
  106. process_sdram_config() {
  107. soc="$1"
  108. in_qts_dir="$2"
  109. in_bsp_dir="$3"
  110. out_dir="$4"
  111. (
  112. cat << EOF
  113. /*
  114. * Altera SoCFPGA SDRAM configuration
  115. *
  116. * SPDX-License-Identifier: BSD-3-Clause
  117. */
  118. #ifndef __SOCFPGA_SDRAM_CONFIG_H__
  119. #define __SOCFPGA_SDRAM_CONFIG_H__
  120. EOF
  121. echo "/* SDRAM configuration */"
  122. # Retrieve the sdram config, zap broken lines and zap parenthesis
  123. sed -n "/\\\\$/ {N;s/ \\\\\n/\t/};p" \
  124. ${in_bsp_dir}/generated/sdram/sdram_config.h |
  125. sed -n '/CONFIG_HPS/ !b; :next {/CONFIG_HPS/ s/[()]//g;/endif/ b;p;n;b next}' |
  126. sort -u | grep_sdram_config
  127. echo ""
  128. echo "/* Sequencer auto configuration */"
  129. sed -n "/__RW_MGR/ {s/__//;s/ \+\([^ ]\+\)$/\t\1/p}" \
  130. ${in_qts_dir}/hps_isw_handoff/*/sequencer_auto.h |
  131. sort -u | grep_sdram_config
  132. echo ""
  133. echo "/* Sequencer defines configuration */"
  134. sed -n "/^#define [^_]/ {s/__//;s/ \+\([^ ]\+\)$/\t\1/p}" \
  135. ${in_qts_dir}/hps_isw_handoff/*/sequencer_defines.h |
  136. sort -u | grep_sdram_config
  137. echo ""
  138. echo "/* Sequencer ac_rom_init configuration */"
  139. sed -n '/^const.*\[/ !b; :next {/^const.*\[/ {N;s/\n//;s/alt_u32/u32/;s/\[.*\]/[]/};/endif/ b;p;n;b next}'\
  140. ${in_qts_dir}/hps_isw_handoff/*/sequencer_auto_ac_init.c
  141. echo ""
  142. echo "/* Sequencer inst_rom_init configuration */"
  143. sed -n '/^const.*\[/ !b; :next {/^const.*\[/ {N;s/\n//;s/alt_u32/u32/;s/\[.*\]/[]/};/endif/ b;p;n;b next}'\
  144. ${in_qts_dir}/hps_isw_handoff/*/sequencer_auto_inst_init.c
  145. cat << EOF
  146. #endif /* __SOCFPGA_SDRAM_CONFIG_H__ */
  147. EOF
  148. ) > "${out_dir}/sdram_config.h"
  149. }
  150. usage() {
  151. echo "$0 [soc_type] [input_qts_dir] [input_bsp_dir] [output_dir]"
  152. echo "Process QTS-generated headers into U-Boot compatible ones."
  153. echo ""
  154. echo " soc_type - Type of SoC, either 'cyclone5' or 'arria5'."
  155. echo " input_qts_dir - Directory with compiled Quartus project"
  156. echo " and containing the Quartus project file (QPF)."
  157. echo " input_bsp_dir - Directory with generated bsp containing"
  158. echo " the settings.bsp file."
  159. echo " output_dir - Directory to store the U-Boot compatible"
  160. echo " headers."
  161. echo ""
  162. }
  163. soc="$1"
  164. in_qts_dir="$2"
  165. in_bsp_dir="$3"
  166. out_dir="$4"
  167. if [ "$#" -ne 4 ] ; then
  168. usage
  169. exit 1
  170. fi
  171. if [ ! -d "${in_qts_dir}" -o ! -d "${in_bsp_dir}" -o \
  172. ! -d "${out_dir}" -o -z "${soc}" ] ; then
  173. usage
  174. exit 3
  175. fi
  176. process_iocsr_config "${soc}" "${in_qts_dir}" "${in_bsp_dir}" "${out_dir}"
  177. process_pinmux_config "${soc}" "${in_qts_dir}" "${in_bsp_dir}" "${out_dir}"
  178. process_pll_config "${soc}" "${in_qts_dir}" "${in_bsp_dir}" "${out_dir}"
  179. process_sdram_config "${soc}" "${in_qts_dir}" "${in_bsp_dir}" "${out_dir}"