Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 1 | if ARCH_SOCFPGA |
| 2 | |
Simon Goldschmidt | a43b60c | 2019-10-22 21:29:48 +0200 | [diff] [blame] | 3 | config ERR_PTR_OFFSET |
| 4 | default 0xfffec000 if TARGET_SOCFPGA_GEN5 # Boot ROM range |
| 5 | |
Simon Goldschmidt | aef4428 | 2019-04-09 21:02:05 +0200 | [diff] [blame] | 6 | config NR_DRAM_BANKS |
| 7 | default 1 |
| 8 | |
Simon Goldschmidt | d6d383c | 2019-06-13 21:50:28 +0200 | [diff] [blame] | 9 | config SPL_SIZE_LIMIT |
Simon Glass | b51882d | 2019-09-25 08:56:28 -0600 | [diff] [blame] | 10 | default 0x10000 if TARGET_SOCFPGA_GEN5 |
Simon Goldschmidt | d6d383c | 2019-06-13 21:50:28 +0200 | [diff] [blame] | 11 | |
| 12 | config SPL_SIZE_LIMIT_PROVIDE_STACK |
| 13 | default 0x200 if TARGET_SOCFPGA_GEN5 |
| 14 | |
Simon Goldschmidt | aef4428 | 2019-04-09 21:02:05 +0200 | [diff] [blame] | 15 | config SPL_STACK_R_ADDR |
| 16 | default 0x00800000 if TARGET_SOCFPGA_GEN5 |
| 17 | |
Simon Goldschmidt | 9dc61aa | 2019-04-09 21:02:06 +0200 | [diff] [blame] | 18 | config SPL_SYS_MALLOC_F_LEN |
| 19 | default 0x800 if TARGET_SOCFPGA_GEN5 |
| 20 | |
Dalon Westergreen | f0fb4fa | 2017-02-10 17:15:34 -0800 | [diff] [blame] | 21 | config SYS_MMCSD_RAW_MODE_U_BOOT_PARTITION_TYPE |
| 22 | default 0xa2 |
| 23 | |
Simon Goldschmidt | aef4428 | 2019-04-09 21:02:05 +0200 | [diff] [blame] | 24 | config SYS_MALLOC_F_LEN |
| 25 | default 0x2000 if TARGET_SOCFPGA_ARRIA10 |
| 26 | default 0x2000 if TARGET_SOCFPGA_GEN5 |
| 27 | |
| 28 | config SYS_TEXT_BASE |
| 29 | default 0x01000040 if TARGET_SOCFPGA_ARRIA10 |
| 30 | default 0x01000040 if TARGET_SOCFPGA_GEN5 |
| 31 | |
Ley Foon Tan | a76b711 | 2019-11-27 15:55:32 +0800 | [diff] [blame] | 32 | config TARGET_SOCFPGA_AGILEX |
| 33 | bool |
| 34 | select ARMV8_MULTIENTRY |
| 35 | select ARMV8_SET_SMPEN |
| 36 | select ARMV8_SPIN_TABLE |
| 37 | select CLK |
| 38 | select NCORE_CACHE |
| 39 | select SPL_CLK if SPL |
| 40 | |
Marek Vasut | cd9b731 | 2015-08-02 21:57:57 +0200 | [diff] [blame] | 41 | config TARGET_SOCFPGA_ARRIA5 |
| 42 | bool |
Dinh Nguyen | ed77aeb | 2015-12-02 13:31:25 -0600 | [diff] [blame] | 43 | select TARGET_SOCFPGA_GEN5 |
Marek Vasut | cd9b731 | 2015-08-02 21:57:57 +0200 | [diff] [blame] | 44 | |
Ley Foon Tan | d89e979 | 2017-04-26 02:44:48 +0800 | [diff] [blame] | 45 | config TARGET_SOCFPGA_ARRIA10 |
| 46 | bool |
Ley Foon Tan | 5918afd | 2019-05-06 09:55:59 +0800 | [diff] [blame] | 47 | select SPL_ALTERA_SDRAM |
Michal Simek | 58008cb | 2018-07-23 15:55:15 +0200 | [diff] [blame] | 48 | select SPL_BOARD_INIT if SPL |
Ley Foon Tan | 3958ef3 | 2020-04-07 15:43:14 +0800 | [diff] [blame] | 49 | select SPL_CACHE if SPL |
Marek Vasut | 934aec7 | 2018-07-30 15:56:19 +0200 | [diff] [blame] | 50 | select CLK |
| 51 | select SPL_CLK if SPL |
Marek Vasut | fe88c2f | 2018-08-13 18:32:38 +0200 | [diff] [blame] | 52 | select DM_I2C |
Marek Vasut | 8145c1c | 2018-08-13 18:32:38 +0200 | [diff] [blame] | 53 | select DM_RESET |
| 54 | select SPL_DM_RESET if SPL |
Marek Vasut | d6a61da | 2018-08-13 20:06:46 +0200 | [diff] [blame] | 55 | select REGMAP |
| 56 | select SPL_REGMAP if SPL |
| 57 | select SYSCON |
| 58 | select SPL_SYSCON if SPL |
| 59 | select ETH_DESIGNWARE_SOCFPGA |
Simon Goldschmidt | aef4428 | 2019-04-09 21:02:05 +0200 | [diff] [blame] | 60 | imply FPGA_SOCFPGA |
Simon Glass | 27084c0 | 2019-09-25 08:56:27 -0600 | [diff] [blame] | 61 | imply SPL_USE_TINY_PRINTF |
Ley Foon Tan | d89e979 | 2017-04-26 02:44:48 +0800 | [diff] [blame] | 62 | |
Marek Vasut | cd9b731 | 2015-08-02 21:57:57 +0200 | [diff] [blame] | 63 | config TARGET_SOCFPGA_CYCLONE5 |
| 64 | bool |
Dinh Nguyen | ed77aeb | 2015-12-02 13:31:25 -0600 | [diff] [blame] | 65 | select TARGET_SOCFPGA_GEN5 |
| 66 | |
| 67 | config TARGET_SOCFPGA_GEN5 |
| 68 | bool |
Ley Foon Tan | 5918afd | 2019-05-06 09:55:59 +0800 | [diff] [blame] | 69 | select SPL_ALTERA_SDRAM |
Simon Goldschmidt | aef4428 | 2019-04-09 21:02:05 +0200 | [diff] [blame] | 70 | imply FPGA_SOCFPGA |
Simon Goldschmidt | d6d383c | 2019-06-13 21:50:28 +0200 | [diff] [blame] | 71 | imply SPL_SIZE_LIMIT_SUBTRACT_GD |
| 72 | imply SPL_SIZE_LIMIT_SUBTRACT_MALLOC |
Simon Goldschmidt | aef4428 | 2019-04-09 21:02:05 +0200 | [diff] [blame] | 73 | imply SPL_STACK_R |
| 74 | imply SPL_SYS_MALLOC_SIMPLE |
Simon Glass | 27084c0 | 2019-09-25 08:56:27 -0600 | [diff] [blame] | 75 | imply SPL_USE_TINY_PRINTF |
Marek Vasut | cd9b731 | 2015-08-02 21:57:57 +0200 | [diff] [blame] | 76 | |
Ley Foon Tan | a684729 | 2018-05-24 00:17:32 +0800 | [diff] [blame] | 77 | config TARGET_SOCFPGA_STRATIX10 |
| 78 | bool |
| 79 | select ARMV8_MULTIENTRY |
Ley Foon Tan | a684729 | 2018-05-24 00:17:32 +0800 | [diff] [blame] | 80 | select ARMV8_SET_SMPEN |
Michal Simek | 58008cb | 2018-07-23 15:55:15 +0200 | [diff] [blame] | 81 | select ARMV8_SPIN_TABLE |
Chee Hong Ang | d217016 | 2020-08-07 11:50:03 +0800 | [diff] [blame^] | 82 | select FPGA_INTEL_SDM_MAILBOX |
Ley Foon Tan | a684729 | 2018-05-24 00:17:32 +0800 | [diff] [blame] | 83 | |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 84 | choice |
| 85 | prompt "Altera SOCFPGA board select" |
Joe Hershberger | a26cd04 | 2015-05-12 14:46:23 -0500 | [diff] [blame] | 86 | optional |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 87 | |
Ley Foon Tan | a76b711 | 2019-11-27 15:55:32 +0800 | [diff] [blame] | 88 | config TARGET_SOCFPGA_AGILEX_SOCDK |
| 89 | bool "Intel SOCFPGA SoCDK (Agilex)" |
| 90 | select TARGET_SOCFPGA_AGILEX |
| 91 | |
Wolfgang Grandegger | 990ed44 | 2019-05-12 19:25:18 +0200 | [diff] [blame] | 92 | config TARGET_SOCFPGA_ARIES_MCVEVK |
| 93 | bool "Aries MCVEVK (Cyclone V)" |
| 94 | select TARGET_SOCFPGA_CYCLONE5 |
| 95 | |
Ley Foon Tan | d89e979 | 2017-04-26 02:44:48 +0800 | [diff] [blame] | 96 | config TARGET_SOCFPGA_ARRIA10_SOCDK |
| 97 | bool "Altera SOCFPGA SoCDK (Arria 10)" |
| 98 | select TARGET_SOCFPGA_ARRIA10 |
| 99 | |
Holger Brunck | 468ba8d | 2020-02-19 19:55:14 +0100 | [diff] [blame] | 100 | config TARGET_SOCFPGA_ARRIA5_SECU1 |
| 101 | bool "ABB SECU1 (Arria V)" |
| 102 | select TARGET_SOCFPGA_ARRIA5 |
| 103 | select VENDOR_KM |
| 104 | |
Marek Vasut | cd9b731 | 2015-08-02 21:57:57 +0200 | [diff] [blame] | 105 | config TARGET_SOCFPGA_ARRIA5_SOCDK |
| 106 | bool "Altera SOCFPGA SoCDK (Arria V)" |
| 107 | select TARGET_SOCFPGA_ARRIA5 |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 108 | |
Marek Vasut | cd9b731 | 2015-08-02 21:57:57 +0200 | [diff] [blame] | 109 | config TARGET_SOCFPGA_CYCLONE5_SOCDK |
| 110 | bool "Altera SOCFPGA SoCDK (Cyclone V)" |
| 111 | select TARGET_SOCFPGA_CYCLONE5 |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 112 | |
Marek Vasut | 7fb4643 | 2018-02-24 23:34:00 +0100 | [diff] [blame] | 113 | config TARGET_SOCFPGA_DEVBOARDS_DBM_SOC1 |
| 114 | bool "Devboards DBM-SoC1 (Cyclone V)" |
| 115 | select TARGET_SOCFPGA_CYCLONE5 |
| 116 | |
Marek Vasut | 856b30d | 2015-11-23 17:06:27 +0100 | [diff] [blame] | 117 | config TARGET_SOCFPGA_EBV_SOCRATES |
| 118 | bool "EBV SoCrates (Cyclone V)" |
| 119 | select TARGET_SOCFPGA_CYCLONE5 |
| 120 | |
Pavel Machek | 35546f6 | 2016-06-07 12:37:23 +0200 | [diff] [blame] | 121 | config TARGET_SOCFPGA_IS1 |
| 122 | bool "IS1 (Cyclone V)" |
| 123 | select TARGET_SOCFPGA_CYCLONE5 |
| 124 | |
Marek Vasut | 94a16b8 | 2019-06-27 00:19:31 +0200 | [diff] [blame] | 125 | config TARGET_SOCFPGA_SOFTING_VINING_FPGA |
| 126 | bool "Softing VIN|ING FPGA (Cyclone V)" |
Tom Rini | e5ec481 | 2017-01-22 19:43:11 -0500 | [diff] [blame] | 127 | select BOARD_LATE_INIT |
Marek Vasut | 569a191 | 2015-12-01 18:09:52 +0100 | [diff] [blame] | 128 | select TARGET_SOCFPGA_CYCLONE5 |
| 129 | |
Marek Vasut | cf0a8da | 2016-06-08 02:57:05 +0200 | [diff] [blame] | 130 | config TARGET_SOCFPGA_SR1500 |
| 131 | bool "SR1500 (Cyclone V)" |
| 132 | select TARGET_SOCFPGA_CYCLONE5 |
| 133 | |
Ley Foon Tan | a684729 | 2018-05-24 00:17:32 +0800 | [diff] [blame] | 134 | config TARGET_SOCFPGA_STRATIX10_SOCDK |
| 135 | bool "Intel SOCFPGA SoCDK (Stratix 10)" |
| 136 | select TARGET_SOCFPGA_STRATIX10 |
| 137 | |
Dinh Nguyen | 55c7a76 | 2015-09-01 17:41:52 -0500 | [diff] [blame] | 138 | config TARGET_SOCFPGA_TERASIC_DE0_NANO |
| 139 | bool "Terasic DE0-Nano-Atlas (Cyclone V)" |
| 140 | select TARGET_SOCFPGA_CYCLONE5 |
| 141 | |
Dalon Westergreen | 6bd041f | 2017-04-18 08:11:16 -0700 | [diff] [blame] | 142 | config TARGET_SOCFPGA_TERASIC_DE10_NANO |
| 143 | bool "Terasic DE10-Nano (Cyclone V)" |
| 144 | select TARGET_SOCFPGA_CYCLONE5 |
| 145 | |
Anatolij Gustschin | e9c847c | 2016-11-14 16:07:10 +0100 | [diff] [blame] | 146 | config TARGET_SOCFPGA_TERASIC_DE1_SOC |
| 147 | bool "Terasic DE1-SoC (Cyclone V)" |
| 148 | select TARGET_SOCFPGA_CYCLONE5 |
| 149 | |
Marek Vasut | 952caa2 | 2015-06-21 17:28:53 +0200 | [diff] [blame] | 150 | config TARGET_SOCFPGA_TERASIC_SOCKIT |
| 151 | bool "Terasic SoCkit (Cyclone V)" |
| 152 | select TARGET_SOCFPGA_CYCLONE5 |
| 153 | |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 154 | endchoice |
| 155 | |
| 156 | config SYS_BOARD |
Ley Foon Tan | a76b711 | 2019-11-27 15:55:32 +0800 | [diff] [blame] | 157 | default "agilex-socdk" if TARGET_SOCFPGA_AGILEX_SOCDK |
Marek Vasut | f089240 | 2015-08-10 21:24:53 +0200 | [diff] [blame] | 158 | default "arria5-socdk" if TARGET_SOCFPGA_ARRIA5_SOCDK |
Ley Foon Tan | d89e979 | 2017-04-26 02:44:48 +0800 | [diff] [blame] | 159 | default "arria10-socdk" if TARGET_SOCFPGA_ARRIA10_SOCDK |
Marek Vasut | f089240 | 2015-08-10 21:24:53 +0200 | [diff] [blame] | 160 | default "cyclone5-socdk" if TARGET_SOCFPGA_CYCLONE5_SOCDK |
Marek Vasut | 7fb4643 | 2018-02-24 23:34:00 +0100 | [diff] [blame] | 161 | default "dbm-soc1" if TARGET_SOCFPGA_DEVBOARDS_DBM_SOC1 |
Dinh Nguyen | 55c7a76 | 2015-09-01 17:41:52 -0500 | [diff] [blame] | 162 | default "de0-nano-soc" if TARGET_SOCFPGA_TERASIC_DE0_NANO |
Anatolij Gustschin | e9c847c | 2016-11-14 16:07:10 +0100 | [diff] [blame] | 163 | default "de1-soc" if TARGET_SOCFPGA_TERASIC_DE1_SOC |
Dalon Westergreen | 6bd041f | 2017-04-18 08:11:16 -0700 | [diff] [blame] | 164 | default "de10-nano" if TARGET_SOCFPGA_TERASIC_DE10_NANO |
Pavel Machek | 35546f6 | 2016-06-07 12:37:23 +0200 | [diff] [blame] | 165 | default "is1" if TARGET_SOCFPGA_IS1 |
Wolfgang Grandegger | 990ed44 | 2019-05-12 19:25:18 +0200 | [diff] [blame] | 166 | default "mcvevk" if TARGET_SOCFPGA_ARIES_MCVEVK |
Holger Brunck | 468ba8d | 2020-02-19 19:55:14 +0100 | [diff] [blame] | 167 | default "secu1" if TARGET_SOCFPGA_ARRIA5_SECU1 |
Marek Vasut | 952caa2 | 2015-06-21 17:28:53 +0200 | [diff] [blame] | 168 | default "sockit" if TARGET_SOCFPGA_TERASIC_SOCKIT |
Marek Vasut | 856b30d | 2015-11-23 17:06:27 +0100 | [diff] [blame] | 169 | default "socrates" if TARGET_SOCFPGA_EBV_SOCRATES |
Stefan Roese | ae9996c | 2015-11-18 11:06:09 +0100 | [diff] [blame] | 170 | default "sr1500" if TARGET_SOCFPGA_SR1500 |
Ley Foon Tan | a684729 | 2018-05-24 00:17:32 +0800 | [diff] [blame] | 171 | default "stratix10-socdk" if TARGET_SOCFPGA_STRATIX10_SOCDK |
Marek Vasut | 94a16b8 | 2019-06-27 00:19:31 +0200 | [diff] [blame] | 172 | default "vining_fpga" if TARGET_SOCFPGA_SOFTING_VINING_FPGA |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 173 | |
| 174 | config SYS_VENDOR |
Ley Foon Tan | a76b711 | 2019-11-27 15:55:32 +0800 | [diff] [blame] | 175 | default "intel" if TARGET_SOCFPGA_AGILEX_SOCDK |
Marek Vasut | cd9b731 | 2015-08-02 21:57:57 +0200 | [diff] [blame] | 176 | default "altera" if TARGET_SOCFPGA_ARRIA5_SOCDK |
Ley Foon Tan | d89e979 | 2017-04-26 02:44:48 +0800 | [diff] [blame] | 177 | default "altera" if TARGET_SOCFPGA_ARRIA10_SOCDK |
Marek Vasut | cd9b731 | 2015-08-02 21:57:57 +0200 | [diff] [blame] | 178 | default "altera" if TARGET_SOCFPGA_CYCLONE5_SOCDK |
Ley Foon Tan | a684729 | 2018-05-24 00:17:32 +0800 | [diff] [blame] | 179 | default "altera" if TARGET_SOCFPGA_STRATIX10_SOCDK |
Wolfgang Grandegger | 990ed44 | 2019-05-12 19:25:18 +0200 | [diff] [blame] | 180 | default "aries" if TARGET_SOCFPGA_ARIES_MCVEVK |
Marek Vasut | 7fb4643 | 2018-02-24 23:34:00 +0100 | [diff] [blame] | 181 | default "devboards" if TARGET_SOCFPGA_DEVBOARDS_DBM_SOC1 |
Marek Vasut | 856b30d | 2015-11-23 17:06:27 +0100 | [diff] [blame] | 182 | default "ebv" if TARGET_SOCFPGA_EBV_SOCRATES |
Holger Brunck | 468ba8d | 2020-02-19 19:55:14 +0100 | [diff] [blame] | 183 | default "keymile" if TARGET_SOCFPGA_ARRIA5_SECU1 |
Marek Vasut | 94a16b8 | 2019-06-27 00:19:31 +0200 | [diff] [blame] | 184 | default "softing" if TARGET_SOCFPGA_SOFTING_VINING_FPGA |
Dinh Nguyen | 55c7a76 | 2015-09-01 17:41:52 -0500 | [diff] [blame] | 185 | default "terasic" if TARGET_SOCFPGA_TERASIC_DE0_NANO |
Anatolij Gustschin | e9c847c | 2016-11-14 16:07:10 +0100 | [diff] [blame] | 186 | default "terasic" if TARGET_SOCFPGA_TERASIC_DE1_SOC |
Dalon Westergreen | 6bd041f | 2017-04-18 08:11:16 -0700 | [diff] [blame] | 187 | default "terasic" if TARGET_SOCFPGA_TERASIC_DE10_NANO |
Marek Vasut | 952caa2 | 2015-06-21 17:28:53 +0200 | [diff] [blame] | 188 | default "terasic" if TARGET_SOCFPGA_TERASIC_SOCKIT |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 189 | |
| 190 | config SYS_SOC |
| 191 | default "socfpga" |
| 192 | |
| 193 | config SYS_CONFIG_NAME |
Ley Foon Tan | a76b711 | 2019-11-27 15:55:32 +0800 | [diff] [blame] | 194 | default "socfpga_agilex_socdk" if TARGET_SOCFPGA_AGILEX_SOCDK |
Holger Brunck | 468ba8d | 2020-02-19 19:55:14 +0100 | [diff] [blame] | 195 | default "socfpga_arria5_secu1" if TARGET_SOCFPGA_ARRIA5_SECU1 |
Dinh Nguyen | 3cbc7b8 | 2015-09-22 17:01:32 -0500 | [diff] [blame] | 196 | default "socfpga_arria5_socdk" if TARGET_SOCFPGA_ARRIA5_SOCDK |
Ley Foon Tan | d89e979 | 2017-04-26 02:44:48 +0800 | [diff] [blame] | 197 | default "socfpga_arria10_socdk" if TARGET_SOCFPGA_ARRIA10_SOCDK |
Dinh Nguyen | 3cbc7b8 | 2015-09-22 17:01:32 -0500 | [diff] [blame] | 198 | default "socfpga_cyclone5_socdk" if TARGET_SOCFPGA_CYCLONE5_SOCDK |
Marek Vasut | 7fb4643 | 2018-02-24 23:34:00 +0100 | [diff] [blame] | 199 | default "socfpga_dbm_soc1" if TARGET_SOCFPGA_DEVBOARDS_DBM_SOC1 |
Dinh Nguyen | 55c7a76 | 2015-09-01 17:41:52 -0500 | [diff] [blame] | 200 | default "socfpga_de0_nano_soc" if TARGET_SOCFPGA_TERASIC_DE0_NANO |
Anatolij Gustschin | e9c847c | 2016-11-14 16:07:10 +0100 | [diff] [blame] | 201 | default "socfpga_de1_soc" if TARGET_SOCFPGA_TERASIC_DE1_SOC |
Dalon Westergreen | 6bd041f | 2017-04-18 08:11:16 -0700 | [diff] [blame] | 202 | default "socfpga_de10_nano" if TARGET_SOCFPGA_TERASIC_DE10_NANO |
Pavel Machek | 35546f6 | 2016-06-07 12:37:23 +0200 | [diff] [blame] | 203 | default "socfpga_is1" if TARGET_SOCFPGA_IS1 |
Wolfgang Grandegger | 990ed44 | 2019-05-12 19:25:18 +0200 | [diff] [blame] | 204 | default "socfpga_mcvevk" if TARGET_SOCFPGA_ARIES_MCVEVK |
Marek Vasut | 952caa2 | 2015-06-21 17:28:53 +0200 | [diff] [blame] | 205 | default "socfpga_sockit" if TARGET_SOCFPGA_TERASIC_SOCKIT |
Marek Vasut | 856b30d | 2015-11-23 17:06:27 +0100 | [diff] [blame] | 206 | default "socfpga_socrates" if TARGET_SOCFPGA_EBV_SOCRATES |
Stefan Roese | ae9996c | 2015-11-18 11:06:09 +0100 | [diff] [blame] | 207 | default "socfpga_sr1500" if TARGET_SOCFPGA_SR1500 |
Ley Foon Tan | a684729 | 2018-05-24 00:17:32 +0800 | [diff] [blame] | 208 | default "socfpga_stratix10_socdk" if TARGET_SOCFPGA_STRATIX10_SOCDK |
Marek Vasut | 94a16b8 | 2019-06-27 00:19:31 +0200 | [diff] [blame] | 209 | default "socfpga_vining_fpga" if TARGET_SOCFPGA_SOFTING_VINING_FPGA |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 210 | |
Holger Brunck | 468ba8d | 2020-02-19 19:55:14 +0100 | [diff] [blame] | 211 | source "board/keymile/Kconfig" |
| 212 | |
Masahiro Yamada | 7865f4b | 2015-04-21 20:38:20 +0900 | [diff] [blame] | 213 | endif |