hwmv2: Introduce Hardware model version 2 and convert devices
This is a squash of the ``collab-hwm`` branch which converts all in-tree boards to hardware model version 2 including build system changes, board updates and soc conversions. This squash is a combination of the following commits: ca214745a1 soc: Remove soc_legacy folder and move ARM Kconfig f12cb0979f scripts: ci: check_compliance: remove HWMv1 checks 1807bcf4d4 boards: mimx8mq_evk: port to HWMv2 3ec2299c62 soc: nxp: port imx8mq SOC to HWMv2 8ea02f4e63 boards: verdin_imx8mp: convert to HVMv2 f2eb7652ce boards: phyboard_pollux: move to HVMv2 ab509a5ee0 boards: nxp: mimx8mp_evk: port M7 core to HWMv2 06ad037f99 soc: nxp: imx8mp: port M7 core to HWMv2 3f9e706859 boards: mimx8mm_phyboard: convert to HVMv2 204372d264 boards: imx8mm_evk: port CM4 core to HWMv2 f82c961a46 soc: nxp: imx8mm: port iMX8MM M4 core to HVMv2 6987b2e305 boards: pico_pi: convert to HVMv2 84484e6707 boards: warp7: convert to HWMv2 ae443d1e3c boards: meerkat96: port to HWMv2 e3629c64e6 boards: colibri_imx7d: port to HWMv2 fc835d893d soc: nxp: convert iMX7 Dual core to HWMv2 29ef2f23eb boards: udoo_neo_full: convert to HWMv2 fd49b1749e soc: nxp: convert iMX6 SoloX core to HWMv2 1e59b7a3fd soc: nxp: imxrt11xx: only set CONFIG_CPU_HAS_FPU_DOUBLE_PRECISION for M7 69bb0eb258 hwmv2: MAINTAINERS: Fix NXP maintainer yaml 1c4458890f boards: firefly: roc_rk3568_pc: Fix SMP configuration 651a4370ad boards: Fix variants and revisions 196cfda66d tests/samples: Drop default revision identifiers 6ec6b1d75a boards: Drop revision from twister identifiers for default revisions b774cdd59f scripts: utils: board_v1_to_v2: drop board_legacy prefix 7aa36e6640 boards: riscv: esp32c3_luatos_core: make usb variant fe25709a9c twister: add unit_testing soc and board f88f211b4e scripts: ci: check_compliance: improve the "not sorted" command b21a455dfb bluetooth: controller: Fix openisa checks fdc76c48a7 workflow: compliance: Add rename limit 14ecafc67d dts: bindings: vendor-prefixes: Sort entries dbc366c3c7 soc: nxp: lpc: Move wrong configurations 8e02c08f96 maintainers: Fix invalid paths b1b85e2495 boards: up: Fix spaces 58cc4013b3 maintainers: Fix xen path 66ce5c0b09 boards/soc: Add missing copyright headers bb47243254 boards: qemu: x86: Remove pointless file 2e816a8a3a samples: tests: update esp32-based board naming 9aeab17139 samples: tests: remove platform_exclude of esp32 boards a4fe97b9de boards: shields: m5stack_core2_ext: update board name 615fcab94a samples: ipm_esp32: fix board labels and skip testing 7752f69b7f boards: legacy: remove index entry for xtensa/riscv boards. 3eba827956 MAINTAINERS: update Espressif entries 914362bbd5 boards: xtensa: yd_esp32: Convert to v2 a62278fd23 boards: xtensa: xiao_esp32s3: Convert to v2 b6a11ccec4 boards: xtensa: olimex_esp32_evb: Convert to v2 c1067c16d2 boards: xtensa: odroid_go: Convert to v2 b8340b0109 boards: xtensa: m5stickc_plus: Convert to v2 9d81e417be boards: xtensa: m5stack_stamps3: Convert to v2 c296672720 boards: xtensa: m5stack_core2: Convert to v2 fada12aa9d boards: xtensa: m5stack_atoms3_lite: Convert to v2 fe37ebac1e boards: xtensa: m5stack_atoms3: Convert to v2 d32828fe6a boards: xtensa: kincony_kc868_a32: Convert to v2 5afba7855b boards: xtensa: heltec_wireless_stick_lite_v3: Convert to v2 ca48c17723 boards: xtensa: heltec_wifi_lora32_v2: Convert to v2 db1fd4d229 boards: xtensa: esp32s3_luatos_core: Convert to v2 a78b2552eb boards: xtensa: esp32s3_devkitm: Convert to v2 cc96061d96 boards: xtensa: esp32s2_saola: Convert to v2 ed854e05d1 boards: xtensa: esp32s2_lolin_mini: Convert to v2 4fa1ae8110 boards: xtensa: esp32s2_franzininho: Convert to v2 5543040a18 boards: xtensa: esp_wrover_kit: Convert to v2 2335ae79b3 boards: xtensa: esp32_ethernet_kit: Convert to v2 f910b7ad4f boards: xtensa: esp32_devkitc_wrover: Convert to v2 32104db555 boards: xtensa: esp32_devkitc_wroom: Convert to v2 e23a41200d boards: riscv: icev_wireless: Convert to v2 3c670e4e53 boards: riscv: xiao_esp32c3: Convert to v2 fc7c6a060b boards: riscv: stamp_c3: Convert to v2 22c2edb89c boards: riscv: esp32c3_luatos_core: Convert to v2 0a96dcb778 boards: riscv: esp32c3_devkitm: Convert to v2 be1ee1c446 vendors: update vendors lists 5e6c62137f soc: espressif_esp32: Port to HWMv2 037a3b52a4 boards: Raspberry Pi pico pwm led adjustment 7277cae6fa samples: blinky_pwm: enable pwm_leds in rpi_pico overlay da3e49d34e boards: nxp: update selection of FLASH_MCUX_FLEXSPI_XIP_MEM_TARGET bc8424dd3b soc: nxp: imxrt: move FLASH_MCUX_FLEXSPI_XIP_MEM_TARGET to SOC level 041cb52939 soc: brcm: bcm_vk: Rename to bcnvk 576b43a95c soc: Fix SOC_FAMILY name mismatches e8f3e6494d hwmv2: boards: intel: adsp: Fix runner after paths renamed 550399e927 boards: weact: stm32g431_core: Add wrongly deleted file back 08708c909e tests: drivers: flash: Renamed missed board rename 06dac41e68 hwmv2: Convert Seagate Faze board to hwmv2 dd8f842b40 hwmv2: nxp: update MAINTAINER paths for hwmv2 b4d1c04978 hwmv2: lpc: updated overlay and conf files in samples and tests 067c69089e boards: nxp: convert lpcxpresso55s69 to hwmv2 097205b40a hwmv2: Global fix of lpc54114_m4 overlay and conf files d8cfa6fb29 boards: nxp: convert lpcxpresso54114 to hwmv2 c29ed228c6 boards: nxp: convert lpcxpresso55s36 to hwmv2 88cfd3d6ac boards: nxp: convert lpcxpresso55s28 to hwmv2 ad30c940ee boards: nxp: convert lpcxpresso55s16 to hwmv2 9e5a10ec80 boards: nxp: convert lpcxpresso55s06 to hwmv2 5650c83268 boards: nxp: convert lpcxpresso51u68 to hwmv2 82cf44be45 boards: nxp: convert lpcxpresso11u68 to hwmv2 1a9c405a6f soc: nxp: convert LPC SOC family to hardware model V2 f2b536d253 boards: intel: doc: hwmv2: Fix some renamed paths 5ee6058710 samples/tests: Use board revisions b76687602f boards: Add yaml files for boards missing revisions 32ae4918d0 boards: nordic: Fix board names cc1dabca65 MAINTAINERS: Update for renamed folders a37ddce659 soc: xilinx: Rename to xlnx a1393a07f6 soc: xenvm: Rename to xen 813ed00f67 soc: raspberry_pi: Rename to raspberrypi 71317d6798 soc: cadence: Rename to cdns 8cb0c51ec6 soc: broadcom: Rename to brcm 2b9db15c69 soc: andes: Rename to andestech 0101216ce1 soc: altera: Rename to altr 4b4c3ca65d boards: wurth_elektronik: Rename to we cdc3ef499f boards: ublox: Rename to u-blox cabdd4ad05 boards: space_cubics: Rename to sc 4b5bd7ae8a boards: seeed_studio: Rename to seeed a992785ceb boards: raspberry_pi: Rename to raspberrypi 3c1cdc20fe boards: laird_connect: Rename to lairdconnect 291c7cde2b boards: cadence: Rename to cdns 95db897526 boards: broadcom: Rename to brcm 0a47b94879 boards: beagleboard: Change to beagle 9f9f221c24 boards: andes: Rename to andestech e7869ca38a boards: altera: Rename to altr bf2fb5eca3 various: Change SOC_FAMILY_NRF to SOC_FAMILY_NORDIC_NRF e25730ba56 modules: tf-m: Rename from nordic_nrf to nordic 9e3466606a boards: nordic_nrf: Rename to nordic 09a398dcc8 soc: nordic_nrf: Rename to nordic cb8ffc74f8 boards: renode: Add documentation index 2291ff4b55 boards: arm: riscv32_virtual: Convert to v2 484b7f1996 soc: riscv_renode_virtual: Port to HWMv2 cc5c2fb0c7 soc: raspberry_pi: Fix SOC_SERIES and SOC mismatch 59cb580513 soc: arm: designstart: Fix SOC_SERIES and SOC mismatch aa9e0de7af samples: Fix invalid links a1480cf1cf maintainers: Fix paths 0d719e004b boards: Update documentation links eb5c3e6f79 boards: wurth_elektronik: Drop duplicate prefix a34a3640b7 boards: waveshare: Drop duplicate prefix cf50e950e7 boards: weact: Drop duplicate prefix 737cfb548f boards: sparkfun: Drop duplicate prefix 505494c97a boards: segger: Drop duplicate prefix 4eaf69f37a boards: ruuvi: Drop duplicate prefix a1335caeae boards: ronoth: Drop duplicate prefix a9f7f30bf6 boards: raytac: Drop duplicate prefix 80db4c81b3 boards: qemu: Drop duplicate prefix 433d7e9976 boards: particle: Drop duplicate prefix 4ea79d19e7 boards: olimex: Drop duplicate prefix fd4ae6f6a8 boards: mikroe: Drop duplicate prefix 36080549bd boards: khados: Drop duplicate prefix 169bf8ae1d boards: intel: Drop duplicate prefix 25f04d5222 boards: holyiot: Drop duplicate prefix 11c2af0de8 boards: google: Drop duplicate prefix d5128f4016 boards: ebyte: Drop duplicate prefix 44fbc68cad boards: dragino: Drop duplicate prefix f7fe431b44 boards: contextual_electronics: Drop duplicate prefix 9094fea63b boards: circuit_dojo: Drop duplicate prefix b632acc1fc boards: blue_clover: Drop duplicate prefix 1a3316ebdc boards: bbc: Drop duplicate prefix 71c0344f8c boards: arduino: Drop duplicate prefix f0176fc25f boards: altera: Drop duplicate prefix 36b920ed0f boards: adi: Drop duplicate prefix 22520368d9 boards: adafruit: Drop duplicate prefix 296acfb2bc boards: actinius: Drop duplicate prefix 55063380b7 boards: 96boards: Drop duplicate prefix 1f93394b55 boards: nxp: convert mimxrt595_evk to hardware model v2 e7a4fd2ec1 soc: nxp: rt5xx: convert RT5xx SOC to HWMv2 01942f1d11 twister: normalize platform name when storing files/data 477c8b84dd twister: tests: test with slashes in platform names 64e3e816c4 soc: Add include guards 3a7aa2fa49 gitignore: update the compliance file list 84e1c17ad9 scripts: ci: check_compliance: add a check for board yml file a90f53ad57 boards: sync up the vendor tags and vendor-list af9aa65299 dts: vendor-prefixes: add keep-sorted markers 50f0bf05a3 dts: vendor-prefixes: sort the vendor list a10b614aa4 dts: vendor-prefixes: ensure all prefixes are lowercase 5abe735e93 manifest: update SOF sha for NXP HWMv2 9ab8f64ca9 modules: rename SOC_FAMILY_IMX 483ff8dd4d modules: mcux: remove SOC_FAMILY_NXP_ADSP f113dd5342 samples: update board name 39b31287d9 boards: nxp: Convert i.MX ADSP boards to hardware model v2 1511e356a2 soc: nxp: Port i.MX ADSP family to hardware model v2 c91e25ab47 soc: mec: rename all mec1501x reference to mec15xx 1c231fd939 hwmv2: boards: Convert IMXRT boards 417cff1e60 hwmv2: soc: Port IMXRT family to HWMV2 28d4e41b1b hwmv2: clean up arm64 soc and board empty directory 2b520f83cb hwmv2: port NXP SoC LS1046A to V2 bf7899c645 hwmv2: port nxp_ls1046ardb board to V2 33f7b61866 samples/tests: Rename numaker boards 8f20ea6e93 boards: nuvoton: numaker_pfm: Split into 2 boards 7cf4ff43a1 drivers: pinctrl: imx: align with hwm v2 c68e1fea4e drivers: clock_control: ccm_rev2: align with hwm v2 update 3b49014a0f hwmv2: move imx8mn EVK board to V2 14f344eeab hwmv2: move imx8mp EVK board to V2 40f3f8f22d hwmv2: move imx8mm EVK board to V2 10bf79ea51 hwmv2: move imx8m soc for a-core to V2 8727d5ca80 hwmv2: move imx93 EVK board to V2 c81ef01563 hwmv2: move imx93 soc to V2 5836c1b699 modules: mcux: introduce CONFIG_MCUX_CORE_SUFFIX 338f6f2bf1 doc: update board porting guide to match new hardware model 9639a1b5dc soc: silabs: drop useless defconfigs 981807444e soc: silabs: introduce SOC_GECKO_SDID 5d07e82485 soc: silabs: SOC_FAMILY_* replace SOC_GECKO_SERIES* 2fd081ac86 soc: silabs: align comments with soc tree 66d425f571 soc: silabs: split in families 5bd38f47a9 arch: arch: kconfig: Fix wrong placement of endmenu 00c6ef25be tests/samples: Rename overlay files for renamed boards 0c639b8378 boards: Fix bools and selections c2ef907d1d drivers: flash: it8xxx2: Add missing Kconfigs 553de2ebc9 soc: ite: ec: it8xxx2: Fix SOC_SERIES being in wrong file b8ec0080c2 boards: Documentation link fixes eb7025e50f tests: Update board names for hwmv2 10ef3d4bd2 boards: silab: Add documentation index file ba9fdaa1d6 boards: arm: efr32_radio: Convert to v2 86c8d4a0ca boards: arm: efm32pg_stk3402a: Convert to v2 575ac5cafb manifest: Update hal_silabs 87b2907304 boards: arm: efr32_thunderboard: Convert to v2 14b30055ab boards: arm: efr32mg_sltb004a: Convert to v2 0012bfc15d boards: arm: efr32xg24_dk2601b: Convert to v2 f526225ead boards: arm: efm32wg_stk3800: Convert to v2 19e7df29df boards: arm: efm32pg_stk3401a: Convert to v2 0bd7d963d6 boards: arm: efm32hg_slstk3400a: Convert to v2 795a90f9bf boards: arm: efm32gg_stk3701a: Convert to v2 43d5540be7 boards: arm: efm32gg_slwstk6121a: Convert to v2 065148d856 boards: arm: efm32gg_sltb009a: Convert to v2 1dc9a8aa17 soc: silabs_exx32: Port to HWMv2 763571e878 tests: Expand names dae301b8a3 boards: xen: xenvm: Expand name 19e60eef36 boards: qemu: qemu_cortex_a53: Expand names a0a7c30f28 soc: intel: intel_adsp: Fix issues df9a4223fe scripts: ci: introduce soc name check in check_compliance ed401abaff soc: emsdsp: align SoC name defined in soc.yml to Kconfig SOC setting fc78e5eaa4 MAINTAINERS: update RISC-V arch area paths 4e586958ff boards: convert QEMU RISC-V 64 bit board to Zephyr HWMv2 f4c31a2b86 boards: convert QEMU RV32E board to Zephyr HWMv2 5b2ffc652b boards: convert QEMU RISC-V 32 bit board to Zephyr HWMv2 5db061a4c6 soc/riscv: convert the QEMU virt RISCV-32 SoC to HWMv2 6547845e9d boards: convert SparkFun RED-V Things Plus to Zephyr HWMv2 95a1f96399 boards: convert SiFive HiFive Unmatched to Zephyr HWMv2 e563eb0a62 soc/sifive/sifive_freedom: add SiFive Freedom FU740 SoC 8914bc58b6 boards: convert SiFive HiFive Unleashed to Zephyr HWMv2 7e8de1e781 soc/sifive/sifive_freedom: add SiFive Freedom U540 SoC bfcc2ed18f boards: convert SiFive HiFive1 Rev. B to Zephyr HWMv2 330fc38f9f boards: convert SiFive HiFive1 to Zephyr HWMv2 b9e06f4c38 soc/sifive/sifive_freedom: add SiFive Freedom E310 SoC 4b90b30b9d scripts: west_commands: completion: Add hwmv2 complete to fish 0f6842e2fa scripts: west_commands: completion: Add hwmv2 complete to zsh b2af1e1737 scripts: west: list_boards: Fix hwmv2 output 686a4b78b8 scripts: west_commands: completion: Add hwmv2 complete to bash 396b6bb856 soc: nxp: fix typo in SoC name 765299c627 soc: broadcom: align SoC names defined in soc.yml to Kconfig SOC setting 7efd46eb41 soc: arm: align SoC names defined in soc.yml to Kconfig SOC setting 505cbc5c42 soc: mec: align SoC names defined in soc.yml to Kconfig SOC setting 951a140701 soc: ti: define SOC name in Kconfig a795d28810 snippets: Initial HWMv2 support f9a957e6f6 boards: nordic: nrf9160dk: Fix missing nrf52840 config df994e7ee8 soc: xilinx: zync7000: Remove xilinx from soc series name 8dfabd56ca soc: cypress: Add protection guard to file 447b951593 tests: kernel: tickless: Remove old board name bad5dfa71f boards: nordic: nrf5340dk: Fix board names ad2e863f39 soc: atmel: Use new family prefix 3f08e714b2 soc: intel_adsp: hwmv2: Align SOC_SERIES_INTEL_ACE name and value 6734597a76 soc: intel_adsp_cavs: hwmv2: Align SOC_SERIES name and value 2908af0bcc boards: nrf51dk/dongle: change SoC to nRF51822 d1ceb29fca soc: align CONFIG_SOC values to match soc.yml names 4768ccaf70 tests: drivers: gpio: gpio_api_1pin: exclude hifive1 ebdb0879ad boards: nxp: s32z2xxdc2: convert to hwmv2 ae82580d08 boards: nxp: mr_canhubk3: convert to hwmv2 c5f0defbae boards: nxp: ucans32k1sic: convert to hwmv2 1e46cabce6 soc: nxp: convert NXP S32 family to hwmv2 f2f85133f2 soc: stm32: Rename series path 86642f4e78 soc: stm32: Rename Kconfig SOC_SERIES symbols c61e807896 soc: stm32: Cleanup Kconfig.defconfig files ca46c8abc9 tests: Fix board names fbfed5f48f maintainers: Update synopsys entries 8cd8b1cc47 boards: synopsys: Add documentation index 6f6cc57a04 boards: arc: hsdk4xd: Convert to v2 c4c14a54ca soc: snps_arc_hsdk4xd: Port to HWMv2 06c2054e5c boards: arc: iotdk: Convert to v2 ff0e0fce1b soc: snps_arc_iot: Port to HWMv2 334264c46a boards: arc: emsdp: Convert to v2 8b947a0e91 soc: snps_emsdp: Port to HWMv2 990417bbde tests: Update board names for hwmv2 e12719154a boards: arc: em_starterkit: Convert to v2 437a430fbe soc: snps_emsk: Port to HWMv2 f93387f968 boards: arc: hsdk: Convert to v2 1cf2498b13 soc: snps_arc_hsdk: Port to HWMv2 47abe81256 boards: arc: nsim: Convert to v2 1e33786dc4 soc: snps_nsim: Port to HWMv2 7f081914db boards: arc: qemu_arc: Convert to v2 bc97349dbd soc: snps_qemu: Port to HWMv2 a9902ff58e boards: Use zephyr_file for file links 126e1a4e72 boards: Fix invalid documentation links 899f0257c3 boards: stm32wb: Restore missing .defconfig files 790c10b1ee soc: x86/atom: imply mmu, do not select it faee62088d boards: x86: remove qemu_x86_tiny_768 c34d186a57 x86: atom: remove soc.h with unused content 1be3a9e9d3 x86: remove legacy ia32, use atom instead 60e6b400f9 boards: qemu: move qemu_x86 -> x86 c4fbac27e8 boards: infineon: Add documentation index b4dd29a9c4 maintainers: Update paths for hwmv2 380f5fdb2b boards: cypress: Add documentation index 9de981be05 boards: arm: xmc47_relax_kit: Convert to v2 6394e8a348 boards: arm: xmc45_relax_kit: Convert to v2 04dbf17e19 soc: xmc_4xxx: Port to HWMv2 c9731f1bce boards: arm: cy8cproto_063_ble: Convert to v2 53d41869d1 boards: arm: cy8cproto_062_4343w: Convert to v2 46c4f01427 boards: arm: cy8ckit_062s4: Convert to v2 d285e19cf2 boards: arm: cy8ckit_062_wifi_bt: Convert to v2 2bebd7298c boards: arm: cy8ckit_062_ble: Convert to v2 af243274c2 soc: psoc6 and psoc_6: Port to HWMv2 105a2bae84 cmake: modules: boards: Fix board deprecation for HWMv2 dca54e000a cmake: modules: boards: Enhance board aliases for HWMv2 fc314e8e3f cmake: modules: boards: Fix BOARD_ALIAS 9a7c2ce6d5 soc: gaisler: Move Kconfig file 1ac56d0501 soc: soc_legacy: mips: Remove out file c054381a7a boards: adjust few boards/ paths 4d93b8d9fd boards: convert all microchip MEC boards to hwmv2 ab2fcb1245 soc: convert microchip_mec to hwmv2 ead4b57a7b soc: arm64: intel_socfpga: hwmv2: Rename SoCs d4c143d306 MAINTAINERS: intel_socfpga: Adjust to HWMv2 move 70a66ac03a boards: arm64: intel_socfpga: Move boards to subdirectories 8a85c07799 boards: arm64: intel_socfpga_agilex5_socdk: move to HWMv2 8c253a99fc boards: arm64: intel_socfpga_agilex_socdk: move to HWMv2 ab883b8019 soc: arm64: intel_socfpga: Move and convert to HWMv2 7c8b7a153b soc: arm: intel_socfpga_std: Rename with HWMv2 8dc2b911f6 soc: board: intel_socfpga_std: Align names to 'Cyclone V' 402366117a soc: arm: intel_socfpga_std: Align board subdirectory f0a8d12745 boards: arm: cyclonev_socdk: Move to HWMv2 2271f17a86 soc: arm: intel_socfpga_std: Move and convert to HWMv2 841c2a9d99 boards: riscv: beaglev_fire: Convert to v2 3b314531ab boards: riscv: mpfs_icicle: Convert to v2 d4ea2bf70b boards: riscv: m2gl025_miv: Convert to v2 5256e9fcc3 soc: microchip_miv: Port to HWMv2 18e5cf1d51 maintainers: Update path for hwmv2 eab8628f98 boards: arm: qemu_cortex_m3: Convert to v2 1532f2fee1 soc: ti_lm3s6965: Port to HWMv2 430ca6a475 maintainers: Update ambiq paths a9b9b41b91 boards: ambiq: Add index db0271ecbb boards: arm: apollo4p_blue_kxr_evb: Convert to v2 957e2b2061 boards: arm: apollo4p_evb: Convert to v2 5a90a44454 soc: ambiq: Port to HWMv2 a20c113fbd boards: nxp: convert ip_k66f to hwmv2 34e3852a54 boards: nxp: convert usb_kw24d512 to hwmv2 20ad604de6 boards: nxp: convert twr_kv58f220m to hwmv2 2e2a7b7656 boards: nxp: twr_ke18f: convert to hwmv2 f7dcc2eb5e boards: nxp: convert rddrone_fmuk66 to hwmv2 b58e90a2e9 boards: nxp: convert hexiwear to hwmv2 aae6e9e454 boards: nxp: frdm_kw41z: convert to hwmv2 1d3baac2d6 boards: nxp: convert frdm_kl25z to hwmv2 3b1d21483f boards: nxp: frdm_k82f: port to hwmv2 6046e6ded9 boards: nxp: port frdm_k64f to hwmv2 0a7bf9fd79 boards: nxp: port frdm_k22f to hwmv2 dce697c823 boards: nxp: add toctree placeholder 666a353409 soc: nxp: kinetis: convert kinetis SOC family to hardware model V2 89f0a6034b maintainers: Update paths for renesas boards/socs 004bd43c48 tests/samples/snippets: Update board names for hwmv2 a6d756923d boards: arm and arm64: rcar_h3ulcb: Convert to v2 3801216b8d boards: arm64: rcar_salvator_xs_m3: Convert to v2 b7cc30aaea boards: arm: rcar_h3_salvatorx_cr7: Convert to v2 866427ea29 boards: arm: arduino_uno_r4: Convert to v2 2689b3f0ee soc: ra: Port to HWMv2 e7ebc727c8 boards: arm: da1469x_dk_pro: Convert to v2 903265b2bb boards: arm: da14695_dk_usb: Convert to v2 529a78ed51 soc: smartbond: Port to HWMv2 97cf636ae0 boards: arm: rcar_spider_cr52: Convert to v2 6d0c53f3a1 soc: rcar: Port to HWMv2 44e0aa0668 soc: renesas: rzt2m: Move folder structure for more SoCs 85238fc205 boards: misc: Fixed STM32 based boards doc links dffc08af56 boards: riscv: niosv_m: move and convert to HWMv2 545093abe4 boards: riscv: niosv_g: move and convert to HWMv2 ecfa192f1b soc: riscv: intel_niosv: move and convert to HWMv2 fd1e8cdc30 hwmv2: sof: intel_adsp: submanifest provisional link 8bf067e625 doc: boards: intel_adsp: Re-order pages 4833275ccd MAINTAINERS: intel_adsp: Adjust to HWMv2 move b9a70e5ea2 soc: intel_adsp: tools: pylint compliance workaround 18c70cc4bf hwmv2: tests: boards: intel_adsp: Adjust board names ca52baf9de hwmv2: boards: intel_adsp: Overhaul board configurations d1b3bcce64 soc: boards: xtensa: intel_adsp_ace: Rename with HWMv2 f362a8ae2c doc: soc: boards: intel_adsp_cavs25: Rename with HWMv2 51dee5da92 tests: samples: boards: intel_adsp_cavs25: Rename with HWMv2 e66c35e0d0 boards: xtensa: intel_adsp_cavs25: Rename board with HWMv2 d1491a4810 soc: boards: xtensa: intel_adsp_cavs25: Rename with HWMv2 fa0fca79c4 scripts: west: runners: intel_adsp: Adjust path to HWMv2 acd18bfaf7 boards: xtensa: intel_adsp_ace20_lnl: move and convert to HWMv2 546c94b958 boards: xtensa: intel_adsp_ace15_mtpm: move and convert to HWMv2 8aab718c3e boards: xtensa: intel_adsp_cavs25_tgph: change to board variant 30f17424a4 boards: xtensa: intel_adsp_cavs25: move and convert to HWMv2 35a97cb524 soc: xtensa: intel_adsp: HWMv2 workaround for SOF config fdc20fdff6 soc: xtensa: intel_adsp: move and convert to HWMv2 22dc2b6391 cmake: improved board handling for revisions 2f1e33a2e6 cmake: improve arch error message for invalid arch selection c47c37d3db sample: basic: blinky_pwm: Exclude rpi_pico w variant 7a788b9a18 boards: raspberry_pi: rpi_pico: Use full name for w variant 7046b92d41 tests: atmel_sam: adc: Fix sam4e_xpro adc build 253ee9638c tests: atmel_sam0: Update platform name ccb4c63324 samples: atmel_sam0: Update platform name 2d4acf9230 boards: arduino_nano_33_iot: Convert to HWMv2 a60d28969a boards: arduino_mkrzero: Convert to HWMv2 0409e51d3f boards: arduino_zero: Convert to HWMv2 1b2528df1b boards: wio_terminal: Convert to HWMv2 af1096e7ca boards: ev11l78a: Convert to HWMv2 0b1db9c53d boards: adafruit_trinket_m0: Convert to HWMv2 e9874671e2 boards: adafruit_itsybitsy_m4_express: Convert to HWMv2 ba6c014071 boards: adafruit_grand_central_m4_express: Convert to HWMv2 33ad4a51ca boards: adafruit_feather_m0_lora: Convert to HWMv2 9812f3d54e boards: adafruit_feather_m0_basic_proto: Convert to HWMv2 c76b1fbeca boards: serpente: Convert to HWMv2 649789e433 boards: seeeduino_xiao: Convert to HWMv2 6b3bdb7364 boards: same54_xpro: Convert to HWMv2 93dda5ee4b boards: samr34_xpro: Convert to HWMv2 e48e1f5d5b boards: samc21n_xpro: Convert to HWMv2 f11cf73df1 boards: saml21_xpro: Convert to HWMv2 ac73ed6dcd boards: samd20_xpro: Convert to HWMv2 0fdbe3552e boards: samd21_xpro: Convert to HWMv2 854cff3905 boards: samr21_xpro: Convert to HWMv2 a87ea5bc0a soc: atmel: sam0: Port to HWMv2 706e5d27cd boards: riscv: neorv32: Convert to v2 d1edcdd088 soc: neorv32: Port to HWMv2 0f7add89ca boards: native_sim/posix: Add 64bit versions as variants b6edad8d68 soc: soc_legacy: remove the arm/st_stm32 folder c58e0822a6 boards: Convert nucleo_f207zg to HWM v2 b987093a80 soc: v2: stm32: Migrate STM32F2 series 2096fd4652 samples: bluetooth: hci_uart: Fix wrongly converted board names 830f9c5a82 MAINTAINERS: Update Atmel entries 527cd9d8cd CODEOWNERS: Update Atmel entries 83af7d0c1c samples: atmel_sam: Update platform name fd9b84d457 tests: atmel_sam: Update platform name 3c72fe863c boards: arduino_due: Convert to HWMv2 37dfacbf9e boards: RoboKit1: Convert to HWMv2 1108d7b0ed boards: sam_v71_xult: Convert to HWMv2 bed44a5c28 boards: sam_e70_xplained: Convert to HWMv2 40448c5a9f boards: sam4s_xplained: Convert to HWMv2 31273692c0 boards: sam4l_ek: Convert to HWMv2 35b5d33ef0 boards: sam4e_xpro: Convert to HWMv2 3b84b9910a soc: atmel: Port SAM family to HWMv2 da00d0e7b9 boards: Convert nucleo_wba55cg to HWM v2 fb2103f89e boards: Convert nucleo_wba52cg to HWM v2 1f9a533fbc soc: st: stm32: Migrate STM32WBA series 3f92f65b28 boards: fix documentation for alientek and blues boards 7646b74aaf boards: stm32l4: doc: add zephyr_file to defconfig path fea54ddcd9 boards: Convert adi_eval_adin2111ebz to HWM v2 d47f1878b1 boards: Convert adi_eval_adin1110ebz to HWM v2 ae42be236b boards: Convert swan_r5 to HWM v2 83bd1a9ecc boards: Convert stm32l4r9i_disco to HWM v2 39c26f09ed boards: Convert stm32l496g_disco to HWM v2 29d03c970b boards: Convert stm32l476g_disco to HWM v2 74acec315c boards: Convert sensortile_box to HWM v2 fee6d8676e boards: Convert pandora_stm32l475 to HWM v2 008b5d9392 boards: Convert nucleo_l4r5zi to HWM v2 24e357d623 boards: Convert nucleo_l4a6zg to HWM v2 2c5f9dcce0 boards: Convert nucleo_l496zg to HWM v2 4da061646f boards: Convert nucleo_l476rg to HWM v2 15956a69b8 tests: drivers: flash: stm32: update platform name 80324f7707 boards: Convert nucleo_l452re_p to HWM v2 9893e0d111 boards: Convert nucleo_l452re to HWM v2 46f92b227b boards: Convert nucleo_l433rc_p to HWM v2 ed5d1bb4cd boards: Convert nucleo_l432kc to HWM v2 325f95ec20 boards: Convert nucleo_l412rb_p to HWM v2 d055676307 boards: Convert disco_l475_iot1 to HWM v2 c7a415d92c boards: Convert b_l4s5i_iot01a to HWM v2 d15144f582 soc: st: stm32: Migrate STM32L4 series a63ff71bcb boards: nrf_bsim: Add new nrf5340 board definitions b53c6f412c boards: nrf_bsim: Remove redundant option setting 83eb4fc069 MAINTAINERS: intel_ish: Adjust to HWMv2 move 715685b19f boards: x86: intel_ish: move and convert intel_ish boards to HWMv2 5b9ef94106 soc: x86: intel_ish: move and convert to HWMv2 12b297707a boards: Convert stm32wb5mmg to HWM v2 cdcea932bc boards: Convert stm32wb5mm_dk to HWM v2 0a3ae2b223 boards: Convert nucleo_wb55rg to HWM v2 20b4ce17d5 soc: st: stm32: Migrate STM32WB series 47c65400d6 soc: st: stm32: fix stm32l0 family 59ec56f9e6 boards: Convert stm32h573i_dk to HWM v2 dc5977dbba boards: Convert nucleo_h563zi to HWM v2 a6e4928543 soc: st: stm32: Migrate STM32H5 series 99f248e048 soc: stm32u5: Fix references after conversion to hw modelv2 15f16834e6 boards: Convert stm32u5a9j_dk to HWM v2 c1ee449ef1 boards: Convert sensortile_box_pro to HWM v2 db4deddf9d boards: Convert nucleo_u5a5zj_q to HWM v2 2fd3ed43d2 boards: Convert nucleo_u575zi_q to HWM v2 902fceb173 boards: Convert b_u585i_iot02a to HWM v2 d716ca1a10 soc: st: Migrate stm32u5 series to new hw model b7abc89428 hwmv2: boards: x86: doc: Adjust common docs to new locations 69b334f54b MAINTAINERS: Change paths to native and nrf*bsim boards 614611a528 boards: nrf*_bsim: Convert to HW model v2 5821b9ec2e board: native_sim/posix: Convert to hwmv2 04cbad174e soc: native: Convert to HWMv2 24ca0febfc boards: nrf_bsim: Fix path to pinctrl_soc.h 9a32559a2d cmake: FindHostTools: Fix for hwmv2 for host based targets c4b11e0251 boards: longan_nano: port to HWMv2 97edd05be3 boards: gd32vf103c_starter: port to HWMv2 9cf624c410 boards: gd32vf103v_eval: port to HWMv2 b40bf25e5e soc: gd_gd32: reorganize folders 71600d7e95 soc: gd_gd32: move pinctrl_soc.h content back to soc folder 2bd84a1bc5 soc: gd_gd32: port gd32vf103 series to HWMv2 9dc342143b boards: doc: fix a bunch of broken reference 10392d693d doc: boards: split out shields b2def8ed3a boards: acrn: fix title bf7d3efe78 boards: riscv: tlsr9518adk80d: Convert to v2 c579770e1d soc: telink_tlsr: Port to HWMv2 9131540109 soc: stm32h7: Couple of tests fixes following migration 2efcefc089 boards: Convert stm32h7b3i_dk to HWM v2 d9b295a85b boards: Convert stm32h750b_dk to HWM v2 a2f56bdcd5 boards: Convert stm32h747i_disco to HWM v2 00314155df boards: Convert stm32h735g_disco to HWM v2 b08819dff7 boards: Convert nucleo_h7a3zi_q to HWM v2 56456c16e5 boards: Convert nucleo_h753zi to HWM v2 91f9198dc4 boards: Convert nucleo_h745zi_q to HWM v2 96f1bafbf9 boards: Convert nucleo_h743zi to HWM v2 b290f25baa boards: Convert nucleo_h723zg to HWM v2 9fbe6bf191 boards: Convert fk7b0m1_vbt6 to HWM v2 44bcfe57c7 boards: Convert arduino_portenta_h7 to HWM v2 4c86af7eae boards: Convert arduino_opta_m4 to HWM v2 b4f852f738 boards: Convert arduino_giga_r1 to HWM v2 bac9789264 soc: st: Migrate stm32h7 series to new hw model a954e1722d boards: stm32l0: Cleanup board _defconfig files after migration 7e8515b241 boards: Convert ronoth_lodev to HWM v2 25246c21ef boards: Convert nucleo_l073rz to HWM v2 09396eb2e6 boards: Convert nucleo_l053r8 to HWM v2 70c004fd83 boards: Convert nucleo_l031k6 to HWM v2 e3daa98e79 boards: Convert nucleo_l011k4 to HWM v2 a2de60c6da boards: Convert dragino_nbsn95 to HWM v2 e877ce9cec boards: Convert dragino_lsn50 to HWM v2 2b50218c23 boards: Convert b_l072z_lrwan1 to HWM v2 4a65f55916 soc: st: Migrate stm32l0 series to new hw model cc6e6be01f boards: fix few leftover ITE board references a837303268 soc: stm32: Protect Kconfig symbols by SOC_FAMILY_STM32 88e5959f17 hwm2: Fix unit_testing: it is also a legacy board by now 95e06e8663 cmake: Fix uses of old SOC path d517d3cc24 soc: set linker script for ra4m1 68f9aeddab soc: ite: add SOC_SERIES_ITE_IT8XXX2 guards around ITE options ccf4f48f01 boards: convert ite boards to hwmv2 4a6e286a3b soc: convert ite_ec to hwmv2 12e375f826 doc: handle arch / soc / board docs in new hardware model b4db917de9 boards: Add documentation index files d6e0d27efe samples: bluetooth: hci_uart: Fix wrong named files bc16a7a727 tests: Update board names for hwmv2 2834883843 boards: riscv: rv32m1_vega: Convert to v2 9c68231ba9 soc: openisa_rv32m1: Port to HWMv2 986e9619fd soc: starfive_jh71xx: Port to HWMv2 e82932e787 boards: riscv: litex_vexriscv: Convert to v2 cb9339f88f soc: litex_vexriscv: Port to HWMv2 1cd4c34654 boards: riscv: opentitan_earlgrey: Convert to v2 92eadf06b8 soc: opentitan: Port to HWMv2 a8659e170b boards: riscv: titanium_ti60_f225: Convert to v2 359133d725 soc: efinix_sapphire: Port to HWMv2 6d466429ed soc: soc_legacy: riscv: litex_vexriscv: Add updated paths a1ff441eb3 boards: riscv: adp_xc7k_ae350: Convert to v2 ef82a8255c soc: ae350: Port to HWMv2 282204758a samples: boards: stm32: ccm: fix include path 8ca9341195 samples: basic: threads: fix broken reference 8a947f446d boards: nrf52840dk: fix rst syntax 324cb41153 boards: nordic_nrf: fix broken references 963c74df1c boards: intel_(ish|adl|ehl|rpl), up_squared: fix include paths 8d518ce504 boards: legacy: drop empty folders 0fef0cef5b boards: mps2: fix table formatting e52ccc244f boards: add HWMv2 board index c7426eca5e boards: arm: add legacy tag 1eba9d8a8f boards: acrn: create vendor folder 8d92edc727 tests: kernel: Adjust qemu_x86_tiny_768 configuration HWMv2 75117d1b2d scripts: ensure posix path is used with --cmakeformat 0b0384b56a maintainers: update paths after HWMv2 changes c1b77b223d boards: arm: pan1783: Convert to v2 91a077b2ab boards: posix: nrf_bsim: Update paths 413b6c2a40 cmake: modules: configuration_files: Add board identifier overlay file 4f572ba24f treewide: Update board names for hwmv2 cb348c7edf boards: arm: nrf54l15pdk_nrf54l15: Convert to v2 811ad90566 boards: arm: nrf54h20pdk_nrf54h20: Convert to v2 d44ef90cf8 soc: nordic_nrf: Migrate nRF54H/nRF54L to v2 and fix nrf c860f205de boards: arm: nrf9151dk_nrf9151: Convert to v2 fba98a1763 soc: nordic_nrf: Migrate nRF9151 to v2 5c156a2d35 boards: arm: 96b_carbon_nrf51: Convert to v2 cfc47a3a4b boards: arm: nrf9161dk_nrf9161: Convert to v2 37129b4e44 boards: arm: nrf9131ek_nrf9131: Convert to v2 a923beba5d boards: arm: bl5340_dvk: Convert to v2 d242b2703b boards: arm: raytac_mdbt53v_db_40_nrf5340: Convert to v2 9c80d4e644 boards: arm: raytac_mdbt53_db_40: Convert to v2 28268c4938 boards: arm: nrf5340_audio_dk_nrf5340: Convert to v2 33ad2b5bc6 boards: arm: thingy53_nrf5340: Convert to v2 40daa94f2d boards: arm: nrf9160_innblue22: Convert to v2 2b0dbb9d51 boards: arm: nrf9160_innblue21: Convert to v2 ee6f7697ac boards: arm: sparkfun_thing_plus_nrf9160: Convert to v2 594e4bad6b boards: arm: circuitdojo_feather_nrf9160: Convert to v2 a5803ba099 boards: arm: actinius_icarus: Convert to v2 db8c275456 boards: arm: actinius_icarus_bee: Convert to v2 30177cf53d boards: arm: actinius_icarus_som: Convert to v2 486504cf24 boards: arm: actinius_icarus_som_dk: Convert to v2 dd0672a64c boards: arm: nrf9160dk_*: Convert to v2 c1565b3d14 boards: arm: xiao_ble: Convert to v2 6dd2723314 boards: arm: qemu_cortex_m0: Convert to v2 ee1ce24a42 boards: arm: bbc_microbit: Convert to v2 1952d559f2 boards: arm: rm1xx_dvk: Convert to v2 9e12c3d8bd boards: arm: nrf51dongle_nrf51422: Convert to v2 0ffbc1da33 boards: arm: nrf51_blenano: Convert to v2 be52dfb7b6 boards: arm: nrf51_vbluno51: Convert to v2 4c29d1827f boards: arm: nrf51_ble400: Convert to v2 5b4a9556fd boards: arm: raytac_mdbt53_db_40_nrf5340: Fix typo 69e5d87a15 boards: arm: contextualelectronics_abc: Convert to v2 5e4ace1bbe boards: arm: degu_evk: Convert to v2 2762460a64 boards: arm: pan1781_evb: Convert to v2 fdc3913e76 boards: arm: ubx_evkninab1_nrf52832: Convert to v2 9c9c3a09a1 boards: arm: holyiot_yj16019: Convert to v2 109edc296f boards: arm: blueclover_plt_demo_v2_nrf52832: Convert to v2 7bfcdbbe8f boards: arm: decawave_dwm1001_dev: Convert to v2 0fbb543983 boards: arm: acn52832: Convert to v2 073e0f8080 boards: arm: we_proteus2ev_nrf52832: Convert to v2 197a19f396 boards: arm: ebyte_e73_tbb_nrf52832: Convert to v2 1616fc8ae5 boards: arm: nrf52_vbluno52: Convert to v2 5622077738 boards: arm: nrf52_sparkfun: Convert to v2 a6289516e4 boards: arm: 96b_nitrogen: Convert to v2 439d836883 boards: arm: nrf52_blenano2: Convert to v2 16e65f09c4 boards: arm: arduino_nicla_sense_me: Convert to v2 862efd5a21 boards: arm: thingy52_nrf52832: Convert to v2 dede0f6cd3 boards: arm: nrf52_adafruit_feather: Convert to v2 91e864ea29 boards: arm: nrf52832_mdk: Convert to v2 47ec3e416b boards: arm: ruuvi_ruuvitag: Convert to v2 52f797a227 boards: arm: pinetime_devkit0: Convert to v2 433db339f9 boards: arm: ubx_evkannab1_nrf52832: Convert to v2 a646d3f2d5 boards: arm: ubx_bmd300eval_nrf52832: Convert to v2 d0d434bf86 cmake: print identifier instead of variant c3f5ed8157 boards: arm: we_proteus3ev_nrf52840: Convert to v2 eecff8ee7a boards: arm: nrf52840_mdk_usb_dongle: Convert to v2 34507614f6 boards: arm: nrf52840_mdk: Convert to v2 f02b56cb96 boards: arm: nrf52840_blip: Convert to v2 600c55c92a boards: arm: nrf52840_papyr: Convert to v2 f294bfc5e4 boards: arm: reel_board: Convert to v2 882524d2a0 boards: arm: nrf21540dk_nrf52840: Convert to v2 4bce0e9b39 boards: arm: nrf52840dongle_nrf52840: Convert to v2 d0229c771f boards: arm: particle_argon: Convert to v2 23a0570e64 boards: arm: particle_boron: Convert to v2 b6d3e1764f boards: arm: particle_xenon: Convert to v2 499f3e7902 boards: arm: rak5010_nrf52840: Convert to v2 9ae6b1804d boards: arm: rak4631_nrf52840: Convert to v2 fe2c90da5c boards: arm: pinnacle_100_dvk: Convert to v2 3d4d46698c boards: arm: ubx_evkninab3_nrf52840: Convert to v2 b1afbf0158 boards: arm: ubx_bmd380eval_nrf52840: Convert to v2 9f9897c872 boards: arm: ubx_bmd345eval_nrf52840: Convert to v2 f7fb2030c7 boards: arm: ubx_bmd340eval_nrf52840: Convert to v2 7186432662 boards: arm: raytac_mdbt50q_db_40_nrf52840: Convert to v2 32c4bdc0c4 boards: arm: pan1780_evb: Convert to v2 7b64c638a8 boards: arm: pan1770_evb: Convert to v2 156ee8ad8a boards: arm: mg100: Convert to v2 3d33dadeb0 boards: arm: arduino_nano_33_ble: Convert to v2 4fee7371d2 boards: arm: adafruit_itsybitsy_nrf52840: Convert to v2 ad37a0c222 boards: arm: adafruit_feather_nrf52840: Convert to v2 cf85b7169f boards: arm: bt510: Convert to v2 44b67ac430 boards: arm: bt610: Convert to v2 7dbb65d371 boards: arm: ubx_evkninab4_nrf52833: Convert to v2 5e79cb957d boards: arm: raytac_mdbt50q_db_33_nrf52833: Convert to v2 12bd83a218 boards: arm: pan1782_evb: Convert to v2 1a135ec352 boards: arm: bbc_microbit_v2: Convert to v2 4dbe97e5ea boards: arm: nrf52833dk: Convert to v2 d632b90043 boards: arm: ubx_bmd360eval_nrf52811: Convert to v2 cc1a30f24b boards: arm: we_ophelia1ev_nrf52805: Convert to v2 df0df9000b boards: arm: ubx_bmd330eval_nrf52810: Convert to v2 d2c7972a9a boards: arm: nrf52dk: Convert to v2 202c2bf447 boards: arm: bl654_sensor_board: Convert to v2 c3e36f2042 boards: arm: bl654_usb: Convert to v2 b9dd58aea1 boards: arm: bl654_dvk: Convert to v2 0e1898b093 boards: arm: bl653_dvk: Convert to v2 286f4a7524 boards: arm: bl652_dvk: Convert to v2 d1709cdb37 boards: update nRF51dk board to board scheme v2. 8f040cff2c boards: Update nrf5340dk_nrf5340 to HWMv2 scheme 8c90fae8e0 boards: update nRF52840dk_nrf52840/nrf52811 board to board scheme v2. c828dcc60e boards: common: openocd-nrf5: Add HWMv2 support c79f1b0d94 kconfig: soc: adopt Nordic SoC series to support hw model v2 scheme 3584b30fc1 tests: Update board names for hwmv2 94024d940e boards: arm: arty_a7: Convert to v2 8053c3a8df boards: arm: scobc_module1: Convert to v2 d5473b76fe soc: designstart: Port to HWMv2 f5792b05e7 boards: arm: fvp_baser_aemv8r_aarch32: Convert to v2 ff202daa8e soc: fvp_aemv8r_aarch32: Port to HWMv2 e66cbc2945 boards: arm: v2m_musca_s1: Convert to v2 33b47b2edb boards: arm: v2m_musca_b1: Convert to v2 baeebd31d2 soc: musca: Port to HWMv2 73b257a3f9 boards: arm: v2m_beetle: Convert to v2 85de0888ec soc: beetle: Port to HWMv2 867960a891 manifest: Update modules 6ca677ed3a boards: arm: mps2: Convert to v2 bcf4ad19d4 twister: build_dir: convert / to _ to support hwmv2 0ac386683f soc: Kconfig.v2: Add SOC_PART_NUMBER 9242c3c78f soc: stm32: soc.yml: reorder series 248d17f160 boards: stm32: cleanup 0a67265e99 boards: stm32: fix for boards with revisions f8d44317ee soc: stm32l5: Rename overlays for nucleo_l552ze_q ns target. 400343d17e soc: stm32: Set default on USE_DT_CODE_PARTITION d783ef549a soc: stm32l5: Update stm32l5 non secure targets in various places 643aeac552 boards: Convert stm32l562e_dk to HWM v2 e601d64344 boards: Convert nucleo_l552ze_q to HWM v2 2f7a387b32 soc: st: Migrate stm32l5 series to new hw model 519752efcd boards: xenvm: doc: Remove reference to deleted file 06263dd717 boards: xenvm: Unset HEAP_MEM_POOL_SIZE in gicv3 variant 66b0df5526 boards: qemu_cortex_a53: Fix Kconfig warnings in SMP variant fa07bd9419 boards: mps3: Fix non-secure variant 8f6f0726dd boards: Move xenvm under xen 7b155a7031 boards: Raspberry Pi vendor fix 804697afa5 boards: Move 96b_aerocore to 96boards d2f001e320 boards: x86: acrn: move and convert to HWMv2 ec7f7b3c30 tests: kernel: qemu_x86: adjust to the HWMv2 89dfcddc7e boards: x86: qemu_x86_tiny@768: change to board variant eb724eb6a7 boards: x86: qemu_x86: optimize default HWMv2 configurations 6f1043cde6 boards: x86: qemu_x86: move and convert to HWMv2 cab924cbfb soc: x86: ia32: move and convert to HWMv2 237fdff918 soc: x86: lakemont: move and convert to HWMv2 03042b7704 boards: move 96b_carbon to 96boards folder 767b94414e boards: rename vendor seeed to seeed_studio 07fa3a3d79 boards: Convert olimex_lora_stm32wl_devkit to HWM v2 ba01d3beca boards: Convert nucleo_wl55jc to HWM v2 7ce84f4041 boards: Convert lora_e5_mini to HWM v2 b988bae576 boards: Convert lora_e5_dev_board to HWM v2 6fbf39c726 soc: v2: stm32: Migrate STM32WL series 4a41878442 soc: st: stm32g4: add missing include 1e79ba15f6 boards: Convert weact_stm32g431_core to HWM v2 ffdcb60185 boards: Convert nucleo_g474re to HWM v2 d6acb08d3e boards: Convert nucleo_g431rb to HWM v2 90e592ffd1 boards: Convert b_g474e_dpow1 to HWM v2 eb8a7e3441 soc: st: stm32: Migrate STM32G4 series ada469f237 tests: Update board names for hwmv2 0342433187 boards: arm: npcx9m6f_evb: Convert to v2 c10248d964 boards: arm: npcx7m6fb_evb: Convert to v2 21ddc5e6a6 boards: arm: npcx4m8f_evb: Convert to v2 5500f3ef21 soc: npcx*: Port to HWMv2 e7baf09ede soc: m48x: Port to HWMv2 5bae4a6480 boards: arm: numaker_pfm_m467: Convert to v2 3b0bd70c8c soc: m46x: Port to HWMv2 d52eab9e83 boards: Convert stm32g081b_eval to HWM v2 6f2835cb11 boards: Convert stm32g071b_disco to HWM v2 ca36d331d2 boards: Convert stm32g0316_disco to HWM v2 662cc4e09b boards: Convert nucleo_g0b1re to HWM v2 dd9bc29769 boards: Convert nucleo_g071rb to HWM v2 353da23ffb boards: Convert nucleo_g070rb to HWM v2 acc932b424 boards: Convert nucleo_g031k8 to HWM v2 cea9b140fd boards: Convert google_twinkie_v2 to HWM v2 52e025943a soc: st: stm32: Migrate STM32G0 series 1c7347686a ci: update check_compliance to not create duplicate lines in Kconfig 9debd98799 hwmv2: boards: up_squared_pro_700: Add missed intel_adl changes adab07c42f boards: Convert msp_exp432p401r_launchxl to HWM v2 642aacdcdf soc: ti_simplelink: Add missing SoC 48637066d3 boards: Fix file paths in documentation e983bc2a23 samples/tests: Fix mps3 board name 61e0f32716 boards: Convert stm32f3_seco_d23 to HWM v2 a1688ff641 boards: Convert stm32f3_disco to HWM v2 35fb228599 boards: Convert stm32373c_eval to HWM v2 10e5d1122b boards: Convert nucleo_f334r8 to HWM v2 c319cb19f0 boards: Convert nucleo_f303re to HWM v2 11725ccac1 boards: Convert nucleo_f303k8 to HWM v2 400f7f6a4f boards: Convert nucleo_f302r8 to HWM v2 8d84861390 soc: v2: stm32: Migrate STM32F3 series 85b9eee7e8 boards: arm: kv260_r5: Convert to v2 dafbd638e4 boards: arm: mercury_xu: Convert to v2 3ecd12f415 boards: arm: qemu_cortex_r5: Convert to v2 5db2390e9d soc: xilinx_zyncmp: Port to HWMv2 9ba8195cdc boards: arm: qemu_cortex_a9: Convert to v2 8e94b85361 boards: arm: zybo: Convert to v2 c970127fc2 soc: xilinx_zynq7000: Port to HWMv2 394c75373c boards: arm: ast1030_evb: Convert to v2 f2a1cc8714 soc: ast10x0: Port to HWMv2 28f3f25945 boards: arm: cc3235sf_launchxl: Convert to v2 c3e480f740 boards: arm: cc3220sf_launchxl: Convert to v2 fd5847123f boards: arm: beagleconnect_freedom: Convert to v2 76ba9a0587 boards: arm: cc1352p1_launchxl: Convert to v2 719baa8850 boards: arm: cc1352r1_launchxl: Convert to v2 5060a61ae1 boards: arm: cc1352r_sensortag: Convert to v2 99584be1c5 boards: arm: cc26x2r1_launchxl: Convert to v2 2dc8933942 soc: ti_simplelink: Port to HWMv2 a5b004663b scripts/utils/board_v1_to_v2.py: couple of fixes 77c2c333e5 boards: move 96b_stm32_sensor_mez to 96boards c14ff98650 boards: stm32f411e_disco: delete obsolete file bcdc268ccf boards: Convert stm32mp157c_dk2 to HWM v2 0c8ba92e1f boards: Convert 96b_avenger96 to HWM v2 b54fe33077 soc: v2: stm32: Migrate STM32MP1 series 2ba3639b2a boards: Convert nucleo_c031c6 to HWM v2 dbc5ed79f5 soc: st: stm32: Migrate STM32C0 series ce6d493aa3 boards: Convert stm32l1_disco to HWM v2 a28086a9ca boards: Convert nucleo_l152re to HWM v2 1b2a511d06 boards: Convert 96b_wistrio to HWM v2 ce281f09ab soc: v2: stm32: Migrate STM32L1 series cdb5364fd7 boards: Convert stm32f769i_disco to HWM v2 768f173dcb boards: Convert stm32f7508_dk to HWM v2 21bbbbd9cb boards: Convert stm32f746g_disco to HWM v2 bab4265693 boards: Convert stm32f723e_disco to HWM v2 58f8fe82ba boards: Convert nucleo_f767zi to HWM v2 37e9084070 boards: Convert nucleo_f756zg to HWM v2 d467e7053a boards: Convert nucleo_f746zg to HWM v2 5f2808d7cc boards: Convert nucleo_f722ze to HWM v2 bbb73e7550 soc: st: Migrate stm32f7 series to new hw model e9094afc4d soc: st: stm32: stm32f4: change SOC_STM32F405XG to SOC_STM32F405XX a1712cdd53 boards: Convert stm32f4_disco to HWM v2 5be404b365 boards: Convert stm32f469i_disco to HWM v2 baaa697ab2 boards: Convert stm32f429i_disc1 to HWM v2 69ecab3c90 boards: Convert stm32f412g_disco to HWM v2 2a572e3fb0 boards: Convert stm32f411e_disco to HWM v2 ecfbf42757 boards: Convert stm32f401_mini to HWM v2 e0191d03bb boards: Convert steval_fcu001v1 to HWM v2 4454648976 boards: Convert segger_trb_stm32f407 to HWM v2 f0ad6ee6b8 boards: Convert olimex_stm32_p405 to HWM v2 1f5e228ec8 boards: Convert olimex_stm32_h407 to HWM v2 834bdb615e boards: Convert olimex_stm32_h405 to HWM v2 8f27fa8de2 boards: Convert olimex_stm32_e407 to HWM v2 f8633a9038 boards: Convert nucleo_f446ze to HWM v2 07e0bd2c07 boards: Convert nucleo_f446re to HWM v2 24d7f625dc boards: Convert nucleo_f429zi to HWM v2 157a8cde53 boards: Convert nucleo_f413zh to HWM v2 4ec99c31b0 boards: Convert nucleo_f412zg to HWM v2 a21546140a boards: Convert nucleo_f411re to HWM v2 43f01ab6de boards: Convert nucleo_f410rb to HWM v2 60c16bcb8b boards: Convert nucleo_f401re to HWM v2 2db228d730 boards: Convert mikroe_mini_m4_for_stm32 to HWM v2 73fc26225c boards: Convert mikroe_clicker_2 to HWM v2 6b62d90114 boards: Convert google_dragonclaw to HWM v2 fa845af309 boards: Convert blackpill_f411ce to HWM v2 5c8c3c3be0 boards: Convert blackpill_f401ce to HWM v2 3c02db1290 boards: Convert blackpill_f401cc to HWM v2 7eeb723cb7 boards: Convert black_f407zg_pro to HWM v2 4f9461d068 boards: Convert black_f407ve to HWM v2 a821de8532 boards: Convert az3166_iotdevkit to HWM v2 ba580c7236 boards: Convert adi_sdp_k1 to HWM v2 eb272ddf19 boards: Convert adafruit_feather_stm32f405 to HWM v2 58ed121c3a boards: Convert 96b_stm32_sensor_mez to HWM v2 b0d70959d3 boards: Convert 96b_neonkey to HWM v2 b1088baadc boards: Convert 96b_carbon to HWM v2 18d867b0a9 boards: Convert 96b_argonkey to HWM v2 ee6ede7119 boards: Convert 96b_aerocore2 to HWM v2 b48e70ead9 soc: v2: stm32: Migrate STM32F4 series 14d2b955da cmake: convert path to CMake style before writing Kconfig files 9c4ac6a202 boards: posix: bsim: Update paths 14b57f56d7 tests: drivers: gpio: gpio_ite_it8xxx2_v2: Temp fix f3b173be18 scripts: board_v1_to_v2: Update following move to boards_legacy 05b50f6691 cmake: CMake soc dir variable improvements for HWMv2 a188e01a12 hwmv2: move all ported boards and socs to their final location 22c53e97b5 hwmv2: move all non-ported legacy boards and socs to legacy folders 53f3b181b0 soc: ti_k3: Port to HWMv2 9f19a2075a soc: rk3568: Port to HWMv2 b8928b1628 soc: rk3399: Port to HWMv2 cda3a74868 boards: arm64: qemu_kvm_arm64: Convert to v2 70d704bd20 soc: x86: atom: move and convert to HWMv2 4789e1068e boards: x86: intel_rpl: move and convert raptor_lake boards to HWMv2 384307e3dc soc: x86: raptor_lake: move and convert to HWMv2 ed025df674 boards: x86: intel_ehl: move and convert elkhart_lake boards to HWMv2 994b6e1731 soc: x86: elkhart_lake: move and convert to HWMv2 73b30a04cf boards: x86: up_squared_pro_7000: move and convert to HWMv2 83b133c207 boards: x86: intel_adl: move and convert alder_lake boards to HWMv2 847a12f1e4 soc: alder_lake: move and convert to HWMv2 67f4c8d2a1 samples: up_squared: adjust gpio_counter to HWMv2 5326b5bfc0 boards: x86: up_squared: move and convert to HWMv2 cfd5e691b4 soc: apollo_lake: move and convert to HWMv2 ac9c235741 boards: xtensa: qemu_xtensa: Convert to v2 f198c3a761 ci: update to osource for soc/Kconfig.defconfig files e438e6cad4 ci: add SOC_SERIES_ as false positive in check_compliance.py 95e34da7c1 soc: v2: Convert st_stm32 to st/stm32 313717df76 soc: mps3: Fix missing family 392c3969ed boards: arm: am62x_m4: Convert to v2 8f245d764d tests: Update board names for hwmv2 8f71bb7b4f boards: arm64: khadas_edgev: Convert to v2 e27d23aad0 soc: rk3399: Port to HWMv2 80823b860e boards: arm64: roc_rk3568_pc: Convert to v2 72e4483dec soc: rk3568: Port to HWMv2 bed94669e3 boards: arm64: phycore_am62x_a53: Convert to v2 c01af5a7b8 soc: ti_k3: Port to HWMv2 1e563b4ca3 boards: arm64: xenvm: Convert to v2 76e484adae soc: xenvm: Port to HWMv2 34412f7fe2 boards: arm64: rpi_4b: Convert to v2 9be50e2ca9 soc: bcm2711: Port to HWMv2 bbbed12c2f boards: arm64: qemu_kvm_arm64: Convert to v2 4f5ec7ff8f soc: qemu_virt_arm64: Port to HWMv2 d8d1b9f200 boards: arm64: qemu_cortex_a53: Convert to v2 30bd34b31e soc: qemu_cortex_a53: Port to HWMv2 c20d0dcbb6 boards: arm64: fvp_baser_aemv8r: Convert to v2 02ed6af463 boards: arm64: fvp_base_revc_2xaemv8a: Convert to v2 1b175003a4 soc: fvp_aemv8*: Port to HWMv2 de231b911d boards: v2: Clean up obsolete comments aa9597f6d9 boards: Convert waveshare_open103z to HWM v2 9644828c81 boards: Convert stm32vl_disco to HWM v2 86ab2bd430 boards: Convert stm32_min_dev to HWM v2 d88d3ddcc4 boards: Convert stm32f103_mini to HWM v2 0ccc0204e1 boards: Convert stm3210c_eval to HWM v2 dd9972d782 boards: Convert olimex_stm32_h103 to HWM v2 a2c2e1406d boards: Convert olimexino_stm32 to HWM v2 2d9c62e118 boards: Convert nucleo_f103rb to HWM v2 e8ba99dc59 soc: v2: stm32: Migrate STM32F1 series 9a93916604 tests: Update board names for hwmv2 9c4d94844d boards: arm: bcm958401m2: Convert to v2 feaf4ffba1 boards: arm: bcm958402m2: Convert to v2 87f0827121 soc: bcm_vk: Port to HWMv2 4526be24a5 boards: arm: quick_feather: Convert to v2 cd921d2b97 boards: arm: qomu: Convert to v2 b3c04051fc soc: quicklogic_eos_s3: Port to HWMv2 a73a9e7533 boards: v2: Clean up obsolete comments 8d87bcc167 boards: Convert stm32f0_disco to HWM v2 1933585785 boards: Convert stm32f072_eval to HWM v2 6f9fe5429d boards: Convert stm32f072b_disco to HWM v2 9dc78e4025 boards: Convert stm32f030_demo to HWM v2 35113e8923 boards: Convert nucleo_f091rc to HWM v2 b276aee9a4 boards: Convert nucleo_f070rb to HWM v2 795f8d611b boards: Convert nucleo_f042k6 to HWM v2 2d82646443 boards: Convert nucleo_f031k6 to HWM v2 959786f12d boards: Convert nucleo_f030r8 to HWM v2 81670db2e9 boards: Convert legend to HWM v2 8980430aad boards: Convert google_kukui to HWM v2 ac020f66e0 dts: stm32f0: fix few warnings 5140e4551a boards: v2: doc: Add vendors 77d640e0c9 soc: v2: stm32: Migrate STM32F0 series 0131e1c159 soc: v2: Add st_stm32 structure and common folder 36b63787a7 boards: v2: Add documentation index for converted boards ae02fc5047 boards: sparc: qemu_leon3: Convert to v2 f38f7bb223 boards: sparc: gr716a: Convert to v2 d3cca3580e soc: gr716a: Port to HWMv2 6a8a0c1647 boards: sparc: generic_leon3: Convert to v2 faf22185ce soc: leon3: Port to HWMv2 e94762ecdc tests: Update board names for hwmv2 9afcc27e05 boards: xtensa: qemu_xtensa: Convert to v2 3e4a17018f soc: dc233c: Port to HWMv2 9188fdcd78 boards: xtensa: xt-sim: Convert to v2 fcaa41cb5d soc: xtensa_sample_controller: Port to HWMv2 dbc413f7f7 scripts: board_v1_to_v2: Fix CONFIG_SOC_SERIES_ exclusion 6be3d4bc80 kconfig: remove Kconfig BOARD_RPI_PICO_W safe guard. f4442fa698 boards: v2: Add documentation index for converted boards ec5fbd67f7 boards: nios2: qemu_nios2: Convert to v2 d3ef220460 soc: nios2-qemu: Port to HWMv2 a223f284b5 boards: nios2: altera_max10: Convert to v2 c381edcb73 soc: nios2f-zephyr: Port to HWMv2 97401c7d2a boards: mips: qemu_malta: Convert to v2 e7a3243a24 soc: qemu_malta: Port to HWMv2 bec82c690d boards: v2: Add documentation index for converted boards 94f6f9b636 boards: arm: w5500_evb_pico: Convert to v2 209235ab6e boards: arm: sparkfun_pro_micro_rp2040: Convert to v2 e5b1885907 boards: arm: adafruit_qt_py_rp2040: Convert to v2 4c750818f9 boards: arm: adafruit_kb2040: Convert to v2 8d3896caa4 boards: arm: rpi_pico: Convert to v2 42cff42c42 soc: rpi_pico: Port to HWMv2 c2df4ca9cb scripts: improve yaml schema and board.yml validation for revisions 3970f90f71 cmake: clear BOARD_CACHE when invalid board identifier is given 3a70ee9ccd cmake: improve board revision handling 3cda715fae scripts: board_v1_to_v2: Don't add select CONFIG_SOC_SERIES_FOO dc56a543f3 scripts: board_v1_to_v2: Add License + copyright 87147f88c4 cmake: prefer cache BOARD_IDENTIFIER over extracting from BOARD 65f5dc5b8c cmake: fail when board identifier is applied in legacy hw model 7db2b6efd8 cmake: cache BOARD_IDENTIFIER to preserve it between CMake invocations 85dddac5a2 scripts: using extend in list_boards for variant list 6ae5c4e7fd scripts: utils: add board v1->v2 conversion utility ef834a12d0 maintainers: update Renesas RZT2M path 3ab7830625 boards: renesas: add documentation entry a0c2ca0491 boards: arm: add documentation entry 27ff3654b7 boards: gigadevice: add documentation entry 6e02f43c0a maintainers: update GD32 paths 1bfcf1d974 boards: gd32l233r_eval: convert to HWMv2 6e621ee43f boards: gd32f470i_eval: convert to HWMv2 219b149768 boards: gd32f450z_eval: convert to HWMv2 91c52b0d39 boards: gd32f450v_start: convert to HWMv2 f0e0a973f6 boards: gd32f407v_start: convert to HWMv2 6f592b64c9 boards: gd32f403z_eval: convert to HWMv2 4bcb4b2ac8 boards: gd32f350r_eval: convert to HWMv2 fdc7ed6eb0 boards: gd32e507z_eval: convert to HWMv2 770376250d boards: gd32e507v_start: convert to HWMv2 a6d8b92e86 boards: gd32e103v_eval: convert to HWMv2 a5f8e5daa1 boards: gd32a503v_eval: convert to HWMv2 5ee799cc5f boards: gd32f450i_eval: convert to HWMv2 8aa8ce4ac8 soc: gigadevice: port to HWMv2 4e203c14c7 cmake: enhanced board entry file handling 312265ee04 scripts: make SoC field mandatory in board.yml c12ae3bcbc boards: update Renesas rzt2m board.yml to contain SoC information c5321c1dbe cmake: make SoC optional for boards containing a single SoC bcc06c60ae scripts: support SoC list output for boards db9e46010c twister: update testcase.yaml and sample.yaml to mps3/an547 identifier a988adee7d boards: update arm mps3 an547 board to HWMv2 scheme 7dc2c9db0c soc: use HWMv2 for arm mps3 SoC c506675b7c boards: update Renesas Starter Kit+ for RZ/T2M board to HWMv2 scheme 3abb792073 soc: use HWMv2 for renesas_rzt2m SoC 4f52bc646e cmake: support hw model v2 in arch/Kconfig tree a712b5005b scripts: extend kconfig compliance to verify board / SoC scheme v2 baa55141a1 twister: update twister testplan.py to handle HWMv2 boards 1f026f70eb boards: extend list_boards.py and update boards CMake module bd854a3af8 cmake: introduce arch and soc cmake modules for hw model v2 c9edefa8fd arch: add existing archs to archs.yml for HWMv2 support 61bbfb5ba2 scripts: introduce list_hardware.py for listing of architectures and SoCs a4d1980c35 build: board/ soc: introduce hw model v2 scheme Signed-off-by: Daniel DeGrasse <daniel.degrasse@nxp.com> Signed-off-by: Declan Snyder <declan.snyder@nxp.com> Signed-off-by: Gerard Marull-Paretas <gerard@teslabs.com> Signed-off-by: Sylvio Alves <sylvio.alves@espressif.com> Signed-off-by: Torsten Rasmussen <Torsten.Rasmussen@nordicsemi.no> Signed-off-by: Fabio Baltieri <fabiobaltieri@google.com> Signed-off-by: Dmitrii Golovanov <dmitrii.golovanov@intel.com> Signed-off-by: David Leach <david.leach@nxp.com> Signed-off-by: Emilio Benavente <emilio.benavente@nxp.com> Signed-off-by: Anas Nashif <anas.nashif@intel.com> Signed-off-by: Iuliana Prodan <iuliana.prodan@nxp.com> Signed-off-by: Jiafei Pan <Jiafei.Pan@nxp.com> Signed-off-by: Jérôme Pouiller <jerome.pouiller@silabs.com> Signed-off-by: Filip Kokosinski <fkokosinski@antmicro.com> Signed-off-by: Grzegorz Swiderski <grzegorz.swiderski@nordicsemi.no> Signed-off-by: Gerson Fernando Budke <nandojve@gmail.com> Signed-off-by: Manuel Argüelles <manuel.arguelles@nxp.com> Signed-off-by: Erwan Gouriou <erwan.gouriou@st.com> Signed-off-by: Mahesh Mahadevan <mahesh.mahadevan@nxp.com> Signed-off-by: Alberto Escolar Piedras <alberto.escolar.piedras@nordicsemi.no> Signed-off-by: Francois Ramu <francois.ramu@st.com> Signed-off-by: Guillaume Gautier <guillaume.gautier-ext@st.com> Signed-off-by: Carles Cufi <carles.cufi@nordicsemi.no> Signed-off-by: Abderrahmane Jarmouni <abderrahmane.jarmouni-ext@st.com> Signed-off-by: Yves Vandervennet <yves.vandervennet@nxp.com> Signed-off-by: Jamie McCrae <jamie.mccrae@nordicsemi.no>
This commit is contained in:
parent
418b0a1e65
commit
8dc3f85622
13315 changed files with 159282 additions and 157416 deletions
2
soc/ite/ec/CMakeLists.txt
Normal file
2
soc/ite/ec/CMakeLists.txt
Normal file
|
@ -0,0 +1,2 @@
|
|||
add_subdirectory(common)
|
||||
add_subdirectory(${SOC_SERIES})
|
8
soc/ite/ec/Kconfig
Normal file
8
soc/ite/ec/Kconfig
Normal file
|
@ -0,0 +1,8 @@
|
|||
# Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_FAMILY_ITE_EC
|
||||
|
||||
rsource "*/Kconfig"
|
||||
|
||||
endif # SOC_FAMILY_ITE_EC
|
8
soc/ite/ec/Kconfig.defconfig
Normal file
8
soc/ite/ec/Kconfig.defconfig
Normal file
|
@ -0,0 +1,8 @@
|
|||
# Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_FAMILY_ITE_EC
|
||||
|
||||
rsource "*/Kconfig.defconfig.series"
|
||||
|
||||
endif # SOC_FAMILY_ITE_EC
|
10
soc/ite/ec/Kconfig.soc
Normal file
10
soc/ite/ec/Kconfig.soc
Normal file
|
@ -0,0 +1,10 @@
|
|||
# Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
config SOC_FAMILY_ITE_EC
|
||||
bool
|
||||
|
||||
config SOC_FAMILY
|
||||
default "ite_ec" if SOC_FAMILY_ITE_EC
|
||||
|
||||
rsource "*/Kconfig.soc"
|
11
soc/ite/ec/common/CMakeLists.txt
Normal file
11
soc/ite/ec/common/CMakeLists.txt
Normal file
|
@ -0,0 +1,11 @@
|
|||
zephyr_include_directories(.)
|
||||
|
||||
zephyr_sources(
|
||||
check_regs.c
|
||||
soc_irq.S
|
||||
soc_common_irq.c
|
||||
vector.S
|
||||
)
|
||||
|
||||
zephyr_sources_ifdef(CONFIG_PM power.c)
|
||||
zephyr_sources_ifdef(CONFIG_PM_POLICY_CUSTOM policy.c)
|
243
soc/ite/ec/common/check_regs.c
Normal file
243
soc/ite/ec/common/check_regs.c
Normal file
|
@ -0,0 +1,243 @@
|
|||
/*
|
||||
* Copyright (c) 2021 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#include <zephyr/device.h>
|
||||
#include <soc.h>
|
||||
|
||||
/* SMFI register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(smfi_it8xxx2_regs, 0xd1);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_ECINDAR0, 0x3b);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_ECINDAR1, 0x3c);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_ECINDAR2, 0x3d);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_ECINDAR3, 0x3e);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_ECINDDR, 0x3f);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_SCAR0L, 0x40);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_SCAR0M, 0x41);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_SCAR0H, 0x42);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_HRAMWC, 0x5a);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_HRAMW0BA, 0x5b);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_HRAMW1BA, 0x5c);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_HRAMW0AAS, 0x5d);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_HRAMW1AAS, 0x5e);
|
||||
IT8XXX2_REG_OFFSET_CHECK(smfi_it8xxx2_regs, SMFI_FLHCTRL6R, 0xa2);
|
||||
|
||||
/* EC2I register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(ec2i_regs, 0x06);
|
||||
IT8XXX2_REG_OFFSET_CHECK(ec2i_regs, IHIOA, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(ec2i_regs, IHD, 0x01);
|
||||
IT8XXX2_REG_OFFSET_CHECK(ec2i_regs, LSIOHA, 0x02);
|
||||
IT8XXX2_REG_OFFSET_CHECK(ec2i_regs, IBMAE, 0x04);
|
||||
IT8XXX2_REG_OFFSET_CHECK(ec2i_regs, IBCTL, 0x05);
|
||||
|
||||
/* KBC register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(kbc_regs, 0x0b);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kbc_regs, KBHICR, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kbc_regs, KBIRQR, 0x02);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kbc_regs, KBHISR, 0x04);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kbc_regs, KBHIKDOR, 0x06);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kbc_regs, KBHIMDOR, 0x08);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kbc_regs, KBHIDIR, 0x0a);
|
||||
|
||||
/* PMC register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(pmc_regs, 0x100);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, PM1STS, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, PM1DO, 0x01);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, PM1DI, 0x04);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, PM1CTL, 0x06);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, PM2STS, 0x10);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, PM2DO, 0x11);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, PM2DI, 0x14);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, PM2CTL, 0x16);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pmc_regs, MBXCTRL, 0x19);
|
||||
|
||||
/* eSPI slave register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(espi_slave_regs, 0xd8);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, GCAPCFG1, 0x05);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, CH_PC_CAPCFG3, 0x0b);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, CH_VW_CAPCFG3, 0x0f);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, CH_OOB_CAPCFG3, 0x13);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, CH_FLASH_CAPCFG3, 0x17);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, CH_FLASH_CAPCFG2_3, 0x1b);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESPCTRL0, 0x90);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESGCTRL0, 0xa0);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESGCTRL1, 0xa1);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESGCTRL2, 0xa2);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESUCTRL0, 0xb0);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESOCTRL0, 0xc0);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESOCTRL1, 0xc1);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESPISAFSC0, 0xd0);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_slave_regs, ESPISAFSC7, 0xd7);
|
||||
|
||||
/* eSPI vw register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(espi_vw_regs, 0x9a);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_vw_regs, VW_INDEX, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_vw_regs, VWCTRL0, 0x90);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_vw_regs, VWCTRL1, 0x91);
|
||||
|
||||
/* eSPI Queue 0 registers structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(espi_queue0_regs, 0xd0);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_queue0_regs, PUT_OOB_DATA, 0x80);
|
||||
|
||||
/* eSPI Queue 1 registers structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(espi_queue1_regs, 0xc0);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_queue1_regs, UPSTREAM_DATA, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(espi_queue1_regs, PUT_FLASH_NP_DATA, 0x80);
|
||||
|
||||
/* GPIO register structure check */
|
||||
#ifdef CONFIG_SOC_IT8XXX2_REG_SET_V1
|
||||
IT8XXX2_REG_SIZE_CHECK(gpio_it8xxx2_regs, 0x100);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR31, 0xD5);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR18, 0xE2);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR21, 0xE6);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR29, 0xEE);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR2, 0xF1);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR7, 0xF6);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR14, 0xFD);
|
||||
#elif CONFIG_SOC_IT8XXX2_REG_SET_V2
|
||||
IT8XXX2_REG_SIZE_CHECK(gpio_it8xxx2_regs, 0x2f);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR2, 0x11);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR7, 0x16);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR12, 0x1b);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_PGWCR, 0x1f);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR21, 0x26);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gpio_it8xxx2_regs, GPIO_GCR30, 0x2d);
|
||||
#endif
|
||||
|
||||
/* GCTRL register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(gctrl_it8xxx2_regs, 0x88);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_RSTS, 0x06);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_BADRSEL, 0x0a);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_WNCKR, 0x0b);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_SPCTRL1, 0x0d);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_SPCTRL4, 0x1c);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_RSTC5, 0x21);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, gctrl_pmer2, 0x33);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_EPLR, 0x37);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_IVTBAR, 0x41);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_MCCR2, 0x44);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_P80H81HSR, 0x50);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_P80HDR, 0x51);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_H2ROFSR, 0x53);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_RVILMCR0, 0x5D);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_ECHIPID2, 0x86);
|
||||
IT8XXX2_REG_OFFSET_CHECK(gctrl_it8xxx2_regs, GCTRL_ECHIPID3, 0x87);
|
||||
|
||||
/* PECI register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(peci_it8xxx2_regs, 0x0F);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HOSTAR, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HOCTLR, 0x01);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HOCMDR, 0x02);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HOTRADDR, 0x03);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HOWRLR, 0x04);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HORDLR, 0x05);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HOWRDR, 0x06);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HORDDR, 0x07);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, HOCTL2R, 0x08);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, RWFCSV, 0x09);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, RRFCSV, 0x0A);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, WFCSV, 0x0B);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, RFCSV, 0x0C);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, AWFCSV, 0x0D);
|
||||
IT8XXX2_REG_OFFSET_CHECK(peci_it8xxx2_regs, PADCTLR, 0x0E);
|
||||
|
||||
/* USB Device register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(usb_it82xx2_regs, 0xE9);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_tx_ctrl, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_tx_trans_type, 0x01);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_tx_line_ctrl, 0x02);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_tx_sof_enable, 0x03);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_tx_addr, 0x04);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_tx_endp, 0x05);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_frame_num_msp, 0x06);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_frame_num_lsp, 0x07);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_interrupt_status, 0x08);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_interrupt_mask, 0x09);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_rx_status, 0x0A);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_rx_pid, 0x0B);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, misc_control, 0x0C);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, misc_status, 0x0D);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_rx_connect_state, 0x0E);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_sof_timer_msb, 0x0F);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, usb_ep_regs[0].ep_ctrl, 0x40);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, usb_ep_regs[0].ep_status, 0x41);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs,
|
||||
usb_ep_regs[EP0].ep_transtype_sts, 0x42);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs,
|
||||
usb_ep_regs[EP0].ep_nak_transtype_sts, 0x43);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, usb_ep_regs[3].ep_ctrl, 0x4C);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, usb_ep_regs[3].ep_status, 0x4D);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs,
|
||||
usb_ep_regs[EP3].ep_transtype_sts, 0x4E);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs,
|
||||
usb_ep_regs[EP3].ep_nak_transtype_sts, 0x4F);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, dc_control, 0x50);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, dc_frame_num_lsp, 0x56);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, fifo_regs[0].ep_rx_fifo_data, 0x60);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, fifo_regs[0].ep_tx_fifo_ctrl, 0x74);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs,
|
||||
fifo_regs[EP_EXT_REGS_9X].ext_4_15.epn0n1_ext_ctrl, 0x98);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs,
|
||||
fifo_regs[EP_EXT_REGS_BX].fifo_ctrl.ep_fifo_ctrl, 0xB8);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs,
|
||||
fifo_regs[EP_EXT_REGS_DX].ext_0_3.epn_ext_ctrl, 0xD6);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, host_device_control, 0xE0);
|
||||
IT8XXX2_REG_OFFSET_CHECK(usb_it82xx2_regs, port1_misc_control, 0xE8);
|
||||
|
||||
|
||||
/* KSCAN register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(kscan_it8xxx2_regs, 0x0F);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kscan_it8xxx2_regs, KBS_KSOL, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kscan_it8xxx2_regs, KBS_KSOCTRL, 0x02);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kscan_it8xxx2_regs, KBS_KSI, 0x04);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kscan_it8xxx2_regs, KBS_KSIGDAT, 0x08);
|
||||
IT8XXX2_REG_OFFSET_CHECK(kscan_it8xxx2_regs, KBS_KSOLGOEN, 0x0e);
|
||||
|
||||
/* ADC register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(adc_it8xxx2_regs, 0xf1);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, ADCGCR, 0x03);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, VCH0DATM, 0x19);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, ADCIVMFSCS1, 0x55);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, ADCIVMFSCS2, 0x56);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, ADCIVMFSCS3, 0x57);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, adc_vchs_ctrl[0].VCHCTL, 0x60);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, adc_vchs_ctrl[2].VCHDATM, 0x67);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, ADCDVSTS2, 0x6c);
|
||||
IT8XXX2_REG_OFFSET_CHECK(adc_it8xxx2_regs, ADCCTL1, 0xf0);
|
||||
|
||||
/* Watchdog register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(wdt_it8xxx2_regs, 0x0f);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ETWCFG, 0x01);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ET1PSR, 0x02);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ET1CNTLHR, 0x03);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ET1CNTLLR, 0x04);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ETWCTRL, 0x05);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, EWDCNTLR, 0x06);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, EWDKEYR, 0x07);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, EWDCNTHR, 0x09);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ET2PSR, 0x0a);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ET2CNTLHR, 0x0b);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ET2CNTLLR, 0x0c);
|
||||
IT8XXX2_REG_OFFSET_CHECK(wdt_it8xxx2_regs, ET2CNTLH2R, 0x0e);
|
||||
|
||||
/* SPISC register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(spisc_it8xxx2_regs, 0x28);
|
||||
IT8XXX2_REG_OFFSET_CHECK(spisc_it8xxx2_regs, SPISC_IMR, 0x04);
|
||||
IT8XXX2_REG_OFFSET_CHECK(spisc_it8xxx2_regs, SPISC_RXFSR, 0x07);
|
||||
IT8XXX2_REG_OFFSET_CHECK(spisc_it8xxx2_regs, SPISC_CPUWTXFDB2R, 0x0a);
|
||||
IT8XXX2_REG_OFFSET_CHECK(spisc_it8xxx2_regs, SPISC_RXFRDRB1, 0x0d);
|
||||
IT8XXX2_REG_OFFSET_CHECK(spisc_it8xxx2_regs, SPISC_FTCB1R, 0x19);
|
||||
IT8XXX2_REG_OFFSET_CHECK(spisc_it8xxx2_regs, SPISC_HPR2, 0x1e);
|
||||
IT8XXX2_REG_OFFSET_CHECK(spisc_it8xxx2_regs, SPISC_RXVLISR, 0x27);
|
||||
|
||||
/* PWM register structure check */
|
||||
IT8XXX2_REG_SIZE_CHECK(pwm_it8xxx2_regs, 0x4a);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pwm_it8xxx2_regs, C0CPRS, 0x00);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pwm_it8xxx2_regs, CTR1M, 0x10);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pwm_it8xxx2_regs, C4CPRS, 0x27);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pwm_it8xxx2_regs, CTR2, 0x42);
|
||||
IT8XXX2_REG_OFFSET_CHECK(pwm_it8xxx2_regs, PWMODENR, 0x49);
|
2233
soc/ite/ec/common/chip_chipregs.h
Normal file
2233
soc/ite/ec/common/chip_chipregs.h
Normal file
File diff suppressed because it is too large
Load diff
178
soc/ite/ec/common/pinctrl_soc.h
Normal file
178
soc/ite/ec/common/pinctrl_soc.h
Normal file
|
@ -0,0 +1,178 @@
|
|||
/*
|
||||
* Copyright (c) 2022 ITE Technology Corporation.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#ifndef ZEPHYR_SOC_RISCV_ITE_IT8XXX2_COMMON_PINCTRL_SOC_H_
|
||||
#define ZEPHYR_SOC_RISCV_ITE_IT8XXX2_COMMON_PINCTRL_SOC_H_
|
||||
|
||||
#include <zephyr/devicetree.h>
|
||||
#include <zephyr/dt-bindings/pinctrl/it8xxx2-pinctrl.h>
|
||||
#include <zephyr/types.h>
|
||||
|
||||
/**
|
||||
* @brief ITE IT8XXX2 pin type.
|
||||
*/
|
||||
struct pinctrl_soc_pin {
|
||||
/* Pinmux control group */
|
||||
const struct device *pinctrls;
|
||||
/*
|
||||
* Pin configuration
|
||||
* kSI[7:0] and KSO[15:0] pins only support pull-up, push-pull/open-drain.
|
||||
* GPIO group pinctrl pins (include KSO[17:16]) support impedance,
|
||||
* pull-up/down, voltage selection, input.
|
||||
*/
|
||||
uint32_t pincfg;
|
||||
/* GPIO pin */
|
||||
uint8_t pin;
|
||||
/* Alternate function */
|
||||
uint8_t alt_func;
|
||||
};
|
||||
|
||||
typedef struct pinctrl_soc_pin pinctrl_soc_pin_t;
|
||||
|
||||
/**
|
||||
* @brief PIN configuration bitfield.
|
||||
*
|
||||
* Pin configuration is coded with the following
|
||||
* bit fields.
|
||||
* Pin impedance config [ 0 ]
|
||||
* Pin pull-up/down config [ 4 : 5 ]
|
||||
* Pin voltage selection [ 8 ]
|
||||
* Pin input enable config [ 12 ]
|
||||
* Pin push-pull/open-drain [ 16 ]
|
||||
*/
|
||||
#define IT8XXX2_HIGH_IMPEDANCE 0x1U
|
||||
#define IT8XXX2_PULL_PIN_DEFAULT 0x0U
|
||||
#define IT8XXX2_PULL_UP 0x1U
|
||||
#define IT8XXX2_PULL_DOWN 0x2U
|
||||
#define IT8XXX2_VOLTAGE_3V3 0x0U
|
||||
#define IT8XXX2_VOLTAGE_1V8 0x1U
|
||||
#define IT8XXX2_INPUT_ENABLE 0x1U
|
||||
#define IT8XXX2_PUSH_PULL 0x0U
|
||||
#define IT8XXX2_OPEN_DRAIN 0x1U
|
||||
|
||||
/* Pin tri-state mode. */
|
||||
#define IT8XXX2_IMPEDANCE_SHIFT 0U
|
||||
#define IT8XXX2_IMPEDANCE_MASK 0x1U
|
||||
/* Pin pull-up or pull-down */
|
||||
#define IT8XXX2_PUPDR_SHIFT 4U
|
||||
#define IT8XXX2_PUPDR_MASK 0x3U
|
||||
#define IT8XXX2_PULL_UP_MASK BIT_MASK(1)
|
||||
/* Pin 3.3V or 1.8V */
|
||||
#define IT8XXX2_VOLTAGE_SHIFT 8U
|
||||
#define IT8XXX2_VOLTAGE_MASK 0x1U
|
||||
/* Pin INPUT enable or disable */
|
||||
#define IT8XXX2_INPUT_SHIFT 12U
|
||||
#define IT8XXX2_INPUT_MASK 0x1U
|
||||
/* Pin push-pull/open-drain mode */
|
||||
#define IT8XXX2_PP_OD_SHIFT 16U
|
||||
#define IT8XXX2_PP_OD_MASK BIT_MASK(1)
|
||||
|
||||
/**
|
||||
* @brief Utility macro to obtain configuration of tri-state.
|
||||
*/
|
||||
#define IT8XXX2_DT_PINCFG_IMPEDANCE(__mode) \
|
||||
(((__mode) >> IT8XXX2_IMPEDANCE_SHIFT) & IT8XXX2_IMPEDANCE_MASK)
|
||||
|
||||
/**
|
||||
* @brief Utility macro to obtain configuration of pull-up or pull-down.
|
||||
*/
|
||||
#define IT8XXX2_DT_PINCFG_PUPDR(__mode) \
|
||||
(((__mode) >> IT8XXX2_PUPDR_SHIFT) & IT8XXX2_PUPDR_MASK)
|
||||
|
||||
/**
|
||||
* @brief Utility macro to obtain input voltage selection.
|
||||
*/
|
||||
#define IT8XXX2_DT_PINCFG_VOLTAGE(__mode) \
|
||||
(((__mode) >> IT8XXX2_VOLTAGE_SHIFT) & IT8XXX2_VOLTAGE_MASK)
|
||||
|
||||
/**
|
||||
* @brief Utility macro to obtain input enable.
|
||||
*/
|
||||
#define IT8XXX2_DT_PINCFG_INPUT(__mode) \
|
||||
(((__mode) >> IT8XXX2_INPUT_SHIFT) & IT8XXX2_INPUT_MASK)
|
||||
|
||||
/**
|
||||
* @brief Utility macro to obtain configuration of pull-up or not.
|
||||
*/
|
||||
#define IT8XXX2_DT_PINCFG_PULLUP(__mode) \
|
||||
(((__mode) >> IT8XXX2_PUPDR_SHIFT) & IT8XXX2_PULL_UP_MASK)
|
||||
|
||||
/**
|
||||
* @brief Utility macro to obtain configuration of push-pull/open-drain mode.
|
||||
*/
|
||||
#define IT8XXX2_DT_PINCFG_PP_OD(__mode) \
|
||||
(((__mode) >> IT8XXX2_PP_OD_SHIFT) & IT8XXX2_PP_OD_MASK)
|
||||
|
||||
/**
|
||||
* @brief Utility macro to initialize pincfg field in #pinctrl_pin_t.
|
||||
*
|
||||
* @param node_id Node identifier.
|
||||
*/
|
||||
#define Z_PINCTRL_IT8XXX2_PINCFG_INIT(node_id) \
|
||||
(((IT8XXX2_HIGH_IMPEDANCE * DT_PROP(node_id, bias_high_impedance)) \
|
||||
<< IT8XXX2_IMPEDANCE_SHIFT) | \
|
||||
((IT8XXX2_PULL_PIN_DEFAULT * DT_PROP(node_id, bias_pull_pin_default)) \
|
||||
<< IT8XXX2_PUPDR_SHIFT) | \
|
||||
((IT8XXX2_PULL_UP * DT_PROP(node_id, bias_pull_up)) \
|
||||
<< IT8XXX2_PUPDR_SHIFT) | \
|
||||
((IT8XXX2_PULL_DOWN * DT_PROP(node_id, bias_pull_down)) \
|
||||
<< IT8XXX2_PUPDR_SHIFT) | \
|
||||
((IT8XXX2_VOLTAGE_1V8 * DT_ENUM_IDX(node_id, gpio_voltage)) \
|
||||
<< IT8XXX2_VOLTAGE_SHIFT) | \
|
||||
((IT8XXX2_INPUT_ENABLE * DT_PROP(node_id, input_enable)) \
|
||||
<< IT8XXX2_INPUT_SHIFT) | \
|
||||
((IT8XXX2_OPEN_DRAIN * DT_PROP(node_id, drive_open_drain)) \
|
||||
<< IT8XXX2_PP_OD_SHIFT))
|
||||
|
||||
/**
|
||||
* @brief Utility macro to initialize pinctrls of pinmuxs field in #pinctrl_pin_t.
|
||||
*
|
||||
* @param node_id Node identifier.
|
||||
*/
|
||||
#define Z_PINCTRL_IT8XXX2_PINCTRL_INIT(node_id) \
|
||||
DEVICE_DT_GET(DT_PHANDLE(node_id, pinmuxs))
|
||||
/**
|
||||
* @brief Utility macro to initialize pin of pinmuxs field in #pinctrl_pin_t.
|
||||
*
|
||||
* @param node_id Node identifier.
|
||||
*/
|
||||
#define Z_PINCTRL_IT8XXX2_PIN_INIT(node_id) \
|
||||
DT_PHA(node_id, pinmuxs, pin)
|
||||
/**
|
||||
* @brief Utility macro to initialize alt_func of pinmuxs field in #pinctrl_pin_t.
|
||||
*
|
||||
* @param node_id Node identifier.
|
||||
*/
|
||||
#define Z_PINCTRL_IT8XXX2_ALT_INIT(node_id) \
|
||||
DT_PHA(node_id, pinmuxs, alt_func)
|
||||
|
||||
/**
|
||||
* @brief Utility macro to initialize each pin.
|
||||
*
|
||||
* @param node_id Node identifier.
|
||||
* @param prop Property name.
|
||||
* @param idx Property entry index.
|
||||
*/
|
||||
#define Z_PINCTRL_STATE_PIN_INIT(node_id, prop, idx) \
|
||||
{ .pinctrls = Z_PINCTRL_IT8XXX2_PINCTRL_INIT( \
|
||||
DT_PROP_BY_IDX(node_id, prop, idx)), \
|
||||
.pincfg = Z_PINCTRL_IT8XXX2_PINCFG_INIT( \
|
||||
DT_PROP_BY_IDX(node_id, prop, idx)), \
|
||||
.pin = Z_PINCTRL_IT8XXX2_PIN_INIT( \
|
||||
DT_PROP_BY_IDX(node_id, prop, idx)), \
|
||||
.alt_func = Z_PINCTRL_IT8XXX2_ALT_INIT( \
|
||||
DT_PROP_BY_IDX(node_id, prop, idx)), },
|
||||
|
||||
/**
|
||||
* @brief Utility macro to initialize state pins contained in a given property.
|
||||
*
|
||||
* @param node_id Node identifier.
|
||||
* @param prop Property name describing state pins.
|
||||
*/
|
||||
#define Z_PINCTRL_STATE_PINS_INIT(node_id, prop) \
|
||||
{DT_FOREACH_PROP_ELEM(node_id, prop, Z_PINCTRL_STATE_PIN_INIT)}
|
||||
|
||||
#endif /* ZEPHYR_SOC_RISCV_ITE_IT8XXX2_COMMON_PINCTRL_SOC_H_ */
|
39
soc/ite/ec/common/policy.c
Normal file
39
soc/ite/ec/common/policy.c
Normal file
|
@ -0,0 +1,39 @@
|
|||
/*
|
||||
* Copyright (c) 2022 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#include <zephyr/kernel.h>
|
||||
#include <zephyr/pm/policy.h>
|
||||
#include <soc.h>
|
||||
|
||||
__weak const struct pm_state_info *pm_policy_next_state(uint8_t cpu, int32_t ticks)
|
||||
{
|
||||
const struct pm_state_info *cpu_states;
|
||||
uint8_t num_cpu_states;
|
||||
|
||||
num_cpu_states = pm_state_cpu_get_all(cpu, &cpu_states);
|
||||
|
||||
for (int16_t i = (int16_t)num_cpu_states - 1; i >= 0; i--) {
|
||||
const struct pm_state_info *state = &cpu_states[i];
|
||||
uint32_t min_residency;
|
||||
|
||||
/* check if there is a lock on state + substate */
|
||||
if (pm_policy_state_lock_is_active(
|
||||
state->state, state->substate_id)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
min_residency = k_us_to_ticks_ceil32(state->min_residency_us);
|
||||
/*
|
||||
* The tick interval for the system to enter sleep mode needs
|
||||
* to be longer than or equal to the minimum residency.
|
||||
*/
|
||||
if (ticks >= min_residency) {
|
||||
return state;
|
||||
}
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
38
soc/ite/ec/common/power.c
Normal file
38
soc/ite/ec/common/power.c
Normal file
|
@ -0,0 +1,38 @@
|
|||
/*
|
||||
* Copyright (c) 2021 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#include <zephyr/kernel.h>
|
||||
#include <zephyr/pm/pm.h>
|
||||
#include <soc.h>
|
||||
|
||||
/* Handle when enter deep doze mode. */
|
||||
static void ite_power_soc_deep_doze(void)
|
||||
{
|
||||
/* Enter deep doze mode */
|
||||
riscv_idle(CHIP_PLL_DEEP_DOZE, MSTATUS_IEN);
|
||||
}
|
||||
|
||||
/* Invoke Low Power/System Off specific Tasks */
|
||||
void pm_state_set(enum pm_state state, uint8_t substate_id)
|
||||
{
|
||||
ARG_UNUSED(substate_id);
|
||||
|
||||
switch (state) {
|
||||
/* Deep doze mode */
|
||||
case PM_STATE_STANDBY:
|
||||
ite_power_soc_deep_doze();
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
/* Handle SOC specific activity after Low Power Mode Exit */
|
||||
void pm_state_exit_post_ops(enum pm_state state, uint8_t substate_id)
|
||||
{
|
||||
ARG_UNUSED(state);
|
||||
ARG_UNUSED(substate_id);
|
||||
}
|
54
soc/ite/ec/common/soc_common.h
Normal file
54
soc/ite/ec/common/soc_common.h
Normal file
|
@ -0,0 +1,54 @@
|
|||
/*
|
||||
* Copyright (c) 2017 Jean-Paul Etienne <fractalclone@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
/**
|
||||
* @file configuration macros for riscv SOCs supporting the riscv
|
||||
* privileged architecture specification
|
||||
*/
|
||||
|
||||
#ifndef __SOC_COMMON_H_
|
||||
#define __SOC_COMMON_H_
|
||||
|
||||
#include "chip_chipregs.h"
|
||||
|
||||
#ifndef _ASMLANGUAGE
|
||||
|
||||
#ifdef CONFIG_HAS_ITE_INTC
|
||||
/*
|
||||
* Save current interrupt state of soc-level into ier_setting[] with
|
||||
* disabling interrupt.
|
||||
*/
|
||||
void ite_intc_save_and_disable_interrupts(void);
|
||||
/* Restore interrupt state of soc-level from ier_setting[], use with care. */
|
||||
void ite_intc_restore_interrupts(void);
|
||||
|
||||
extern void ite_intc_irq_enable(unsigned int irq);
|
||||
extern void ite_intc_irq_disable(unsigned int irq);
|
||||
extern uint8_t ite_intc_get_irq_num(void);
|
||||
extern int ite_intc_irq_is_enable(unsigned int irq);
|
||||
extern void ite_intc_irq_polarity_set(unsigned int irq, unsigned int flags);
|
||||
extern void ite_intc_isr_clear(unsigned int irq);
|
||||
void ite_intc_init(void);
|
||||
bool ite_intc_no_irq(void);
|
||||
#endif /* CONFIG_HAS_ITE_INTC */
|
||||
|
||||
#ifdef CONFIG_SOC_IT8XXX2_PLL_FLASH_48M
|
||||
void timer_5ms_one_shot(void);
|
||||
#endif
|
||||
|
||||
uint32_t chip_get_pll_freq(void);
|
||||
void chip_pll_ctrl(enum chip_pll_mode mode);
|
||||
void riscv_idle(enum chip_pll_mode mode, unsigned int key);
|
||||
|
||||
#ifdef CONFIG_SOC_IT8XXX2_CPU_IDLE_GATING
|
||||
void chip_permit_idle(void);
|
||||
void chip_block_idle(void);
|
||||
bool cpu_idle_not_allowed(void);
|
||||
#endif
|
||||
|
||||
#endif /* !_ASMLANGUAGE */
|
||||
|
||||
#endif /* __SOC_COMMON_H_ */
|
42
soc/ite/ec/common/soc_common_irq.c
Normal file
42
soc/ite/ec/common/soc_common_irq.c
Normal file
|
@ -0,0 +1,42 @@
|
|||
/*
|
||||
* Copyright (c) 2017 Jean-Paul Etienne <fractalclone@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
/**
|
||||
* @file
|
||||
* @brief interrupt management code for riscv SOCs supporting the riscv
|
||||
privileged architecture specification
|
||||
*/
|
||||
#include <zephyr/irq.h>
|
||||
|
||||
#include <soc_common.h>
|
||||
|
||||
void arch_irq_enable(unsigned int irq)
|
||||
{
|
||||
if (IS_ENABLED(CONFIG_HAS_ITE_INTC)) {
|
||||
ite_intc_irq_enable(irq);
|
||||
}
|
||||
}
|
||||
|
||||
void arch_irq_disable(unsigned int irq)
|
||||
{
|
||||
if (IS_ENABLED(CONFIG_HAS_ITE_INTC)) {
|
||||
ite_intc_irq_disable(irq);
|
||||
}
|
||||
};
|
||||
|
||||
int arch_irq_is_enabled(unsigned int irq)
|
||||
{
|
||||
/*
|
||||
* Return true from arch_irq_is_enabled() when external interrupt-enable
|
||||
* bit, and SOC's IER are both true.
|
||||
*/
|
||||
if (IS_ENABLED(CONFIG_HAS_ITE_INTC)) {
|
||||
return ((csr_read(mie) & BIT(IRQ_M_EXT)) &&
|
||||
ite_intc_irq_is_enable(irq));
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
89
soc/ite/ec/common/soc_dt.h
Normal file
89
soc/ite/ec/common/soc_dt.h
Normal file
|
@ -0,0 +1,89 @@
|
|||
/*
|
||||
* Copyright (c) 2021 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#ifndef _ITE_IT8XXX2_SOC_DT_H_
|
||||
#define _ITE_IT8XXX2_SOC_DT_H_
|
||||
|
||||
/*
|
||||
* For it8xxx2 wake-up controller (WUC)
|
||||
*/
|
||||
#define IT8XXX2_DEV_WUC(idx, inst) \
|
||||
DEVICE_DT_GET(DT_PHANDLE(IT8XXX2_DT_INST_WUCCTRL(inst, idx), wucs))
|
||||
#define IT8XXX2_DEV_WUC_MASK(idx, inst) \
|
||||
DT_PHA(IT8XXX2_DT_INST_WUCCTRL(inst, idx), wucs, mask)
|
||||
|
||||
/**
|
||||
* @brief For it8xxx2, get a node identifier from a wucctrl property
|
||||
* for a DT_DRV_COMPAT instance
|
||||
*
|
||||
* @param inst instance number
|
||||
* @param idx index in the wucctrl property
|
||||
* @return node identifier for the phandle at index idx in the wucctrl
|
||||
* property of that DT_DRV_COMPAT instance
|
||||
*/
|
||||
#define IT8XXX2_DT_INST_WUCCTRL(inst, idx) \
|
||||
DT_INST_PHANDLE_BY_IDX(inst, wucctrl, idx)
|
||||
|
||||
/**
|
||||
* @brief For it8xxx2, construct wuc map structure in LISTIFY extension
|
||||
*
|
||||
* @param idx index in LISTIFY extension
|
||||
* @param inst instance number for compatible defined in DT_DRV_COMPAT
|
||||
* @return a structure of *_wuc_map_cfg
|
||||
*/
|
||||
#define IT8XXX2_DT_WUC_ITEMS_FUNC(idx, inst) \
|
||||
{ \
|
||||
.wucs = IT8XXX2_DEV_WUC(idx, inst), \
|
||||
.mask = IT8XXX2_DEV_WUC_MASK(idx, inst), \
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief For it8xxx2, get the length of wucctrl property which
|
||||
* type is 'phandle-array' for a DT_DRV_COMPAT instance
|
||||
*
|
||||
* @param inst instance number
|
||||
* @return length of wucctrl property which type is 'phandle-array'
|
||||
*/
|
||||
#define IT8XXX2_DT_INST_WUCCTRL_LEN(inst) \
|
||||
DT_INST_PROP_LEN(inst, wucctrl)
|
||||
|
||||
/**
|
||||
* @brief For it8xxx2, construct an array of it8xxx2 wuc map structure
|
||||
* with compatible defined in DT_DRV_COMPAT by LISTIFY func
|
||||
*
|
||||
* @param inst instance number for compatible defined in DT_DRV_COMPAT
|
||||
* @return an array of *_wuc_map_cfg structure
|
||||
*/
|
||||
#define IT8XXX2_DT_WUC_ITEMS_LIST(inst) { \
|
||||
LISTIFY(IT8XXX2_DT_INST_WUCCTRL_LEN(inst), \
|
||||
IT8XXX2_DT_WUC_ITEMS_FUNC, (,), \
|
||||
inst) \
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief Macro function to construct it8xxx2 GPIO IRQ in LISTIFY extension.
|
||||
*
|
||||
* @param idx index in LISTIFY extension.
|
||||
* @param inst instance number for compatible defined in DT_DRV_COMPAT.
|
||||
* @return an IRQ number of GPIO.
|
||||
*/
|
||||
#define IT8XXX2_DT_GPIO_IRQ_FUNC(idx, inst) \
|
||||
DT_INST_IRQ_BY_IDX(inst, idx, irq)
|
||||
|
||||
/**
|
||||
* @brief Macro function to construct a list of it8xxx2 GPIO IRQ number
|
||||
* with compatible defined in DT_DRV_COMPAT by LISTIFY func.
|
||||
*
|
||||
* @param inst instance number for compatible defined in DT_DRV_COMPAT.
|
||||
* @return an array of GPIO IRQ number.
|
||||
*/
|
||||
#define IT8XXX2_DT_GPIO_IRQ_LIST(inst) { \
|
||||
LISTIFY(DT_INST_PROP(inst, ngpios), \
|
||||
IT8XXX2_DT_GPIO_IRQ_FUNC, (,), \
|
||||
inst) \
|
||||
}
|
||||
|
||||
#endif /* _ITE_IT8XXX2_SOC_DT_H_ */
|
39
soc/ite/ec/common/soc_espi.h
Normal file
39
soc/ite/ec/common/soc_espi.h
Normal file
|
@ -0,0 +1,39 @@
|
|||
/*
|
||||
* Copyright (c) 2021 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#ifndef _ITE_IT8XXX2_SOC_ESPI_H_
|
||||
#define _ITE_IT8XXX2_SOC_ESPI_H_
|
||||
|
||||
#include <zephyr/device.h>
|
||||
#include <zephyr/sys/util.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#define ESPI_IT8XXX2_SOC_DEV DEVICE_DT_GET(DT_NODELABEL(espi0))
|
||||
|
||||
/**
|
||||
* @brief eSPI input pad gating
|
||||
*
|
||||
* @param dev pointer to eSPI device
|
||||
* @param enable/disable eSPI pad
|
||||
*/
|
||||
void espi_it8xxx2_enable_pad_ctrl(const struct device *dev, bool enable);
|
||||
|
||||
/**
|
||||
* @brief eSPI transaction interrupt control
|
||||
*
|
||||
* @param dev pointer to eSPI device
|
||||
* @param enable/disable eSPI transaction interrupt
|
||||
*/
|
||||
void espi_it8xxx2_enable_trans_irq(const struct device *dev, bool enable);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* _ITE_IT8XXX2_SOC_ESPI_H_ */
|
27
soc/ite/ec/common/soc_irq.S
Normal file
27
soc/ite/ec/common/soc_irq.S
Normal file
|
@ -0,0 +1,27 @@
|
|||
/*
|
||||
* Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
/*
|
||||
* common interrupt management code for riscv SOCs supporting the riscv
|
||||
* privileged architecture specification
|
||||
*/
|
||||
#include <zephyr/kernel_structs.h>
|
||||
#include <offsets.h>
|
||||
#include <zephyr/toolchain.h>
|
||||
#include <zephyr/linker/sections.h>
|
||||
#include <soc.h>
|
||||
|
||||
/* exports */
|
||||
GTEXT(__soc_handle_irq)
|
||||
|
||||
/*
|
||||
* SOC-specific function to handle pending IRQ number generating the interrupt.
|
||||
* Exception number is given as parameter via register a0.
|
||||
* Jump to get_irq() function directly and return to caller by its
|
||||
* ret instruction.
|
||||
*/
|
||||
SECTION_FUNC(exception.other, __soc_handle_irq)
|
||||
j get_irq
|
86
soc/ite/ec/common/vector.S
Normal file
86
soc/ite/ec/common/vector.S
Normal file
|
@ -0,0 +1,86 @@
|
|||
/*
|
||||
* Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
* Jyunlin Chen <jyunlin.chen@ite.com.tw>
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#include "chip_chipregs.h"
|
||||
#include <zephyr/toolchain.h>
|
||||
|
||||
/* exports */
|
||||
GTEXT(__start)
|
||||
|
||||
/* imports */
|
||||
GTEXT(__initialize)
|
||||
GTEXT(_isr_wrapper)
|
||||
|
||||
SECTION_FUNC(vectors, __start)
|
||||
#ifdef CONFIG_RISCV_GP
|
||||
.option push
|
||||
.option norelax
|
||||
/* Configure the GP register */
|
||||
la gp, __global_pointer$
|
||||
.option pop
|
||||
#endif
|
||||
|
||||
.option norvc;
|
||||
|
||||
/*
|
||||
* Set mtvec (Machine Trap-Vector Base-Address Register)
|
||||
* to _isr_wrapper.
|
||||
*/
|
||||
la t0, _isr_wrapper
|
||||
csrw mtvec, t0
|
||||
csrwi mie, 0
|
||||
#if (CONFIG_SOC_IT8XXX2_FLASH_SIZE_BYTES == 0x100000)
|
||||
/*
|
||||
* bit[3-0]@EIDSR=8: instruction local memory size is 1M byte
|
||||
* This operation must be done before accessing memory.
|
||||
*/
|
||||
la t0, IT8XXX2_GCTRL_EIDSR
|
||||
lb t1, 0(t0)
|
||||
andi t1, t1, 0xf0
|
||||
ori t1, t1, 0x8
|
||||
sb t1, 0(t0)
|
||||
#endif
|
||||
/* Jump to __initialize */
|
||||
tail __initialize
|
||||
|
||||
/*
|
||||
* eflash signature used to enable specific function after power-on reset.
|
||||
* (HW mechanism)
|
||||
* The content of 16-bytes must be the following and at offset 0x80 of binary.
|
||||
* ----------------------------------------------------------------------------
|
||||
* 1st 2nd 3rd 4th 5th 6th 7th 8th 9th 10th 11th 12th 13th 14th 15th 16th
|
||||
* ----------------------------------------------------------------------------
|
||||
* A5h A5h A5h A5h A5h A5h [host] [flag] 85h 12h 5Ah 5Ah AAh AAh 55h 55h
|
||||
* ----------------------------------------------------------------------------
|
||||
* [host]: A4h = enable eSPI, A5h = enable LPC
|
||||
* [flag]:
|
||||
* bit7: it must be 1b.
|
||||
* bit6: it must be 0b.
|
||||
* bit5: it must be 1b.
|
||||
* bit4: 1b = 32.768KHz is from the internal clock generator.
|
||||
* bit3: it must be 0b.
|
||||
* bit2: it must be 1b.
|
||||
* bit1: it must be 0b.
|
||||
* bit0: it must be 0b.
|
||||
*/
|
||||
.org 0x80
|
||||
.balign 16
|
||||
.global eflash_sig
|
||||
eflash_sig:
|
||||
.byte 0xA5, 0xA5, 0xA5, 0xA5, 0xA5, 0xA5
|
||||
#ifdef CONFIG_ESPI
|
||||
.byte 0xA4 /* enable eSPI */
|
||||
#else
|
||||
.byte 0xA5 /* enable LPC */
|
||||
#endif
|
||||
/* flag of signature */
|
||||
#ifdef CONFIG_SOC_IT8XXX2_EXT_32K
|
||||
.byte 0xA4 /* use external 32.768 kHz oscillator */
|
||||
#else
|
||||
.byte 0xB4 /* enable internal clock generator */
|
||||
#endif
|
||||
.byte 0x85, 0x12, 0x5A, 0x5A, 0xAA, 0xAA, 0x55, 0x55
|
9
soc/ite/ec/it8xxx2/CMakeLists.txt
Normal file
9
soc/ite/ec/it8xxx2/CMakeLists.txt
Normal file
|
@ -0,0 +1,9 @@
|
|||
zephyr_sources(soc.c)
|
||||
zephyr_include_directories(.)
|
||||
|
||||
zephyr_library_sources_ifndef(CONFIG_RISCV_ISA_EXT_M __arithmetic.S)
|
||||
zephyr_sources_ifdef(CONFIG_SOC_IT8XXX2_USE_ILM ilm.c)
|
||||
|
||||
set(SOC_LINKER_SCRIPT ${CMAKE_CURRENT_SOURCE_DIR}/linker.ld
|
||||
CACHE INTERNAL "SoC Linker script ${SOC_NAME}"
|
||||
)
|
154
soc/ite/ec/it8xxx2/Kconfig
Normal file
154
soc/ite/ec/it8xxx2/Kconfig
Normal file
|
@ -0,0 +1,154 @@
|
|||
# Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
config SOC_SERIES_ITE_IT8XXX2
|
||||
select CPU_HAS_FPU if "$(ZEPHYR_TOOLCHAIN_VARIANT)" != "zephyr" || RISCV_ISA_EXT_M
|
||||
select HAS_PM
|
||||
|
||||
if SOC_SERIES_ITE_IT8XXX2
|
||||
|
||||
config SOC_IT8XXX2
|
||||
select RISCV
|
||||
select ATOMIC_OPERATIONS_BUILTIN
|
||||
select RISCV_ISA_RV32I
|
||||
select RISCV_ISA_EXT_ZICSR
|
||||
select RISCV_ISA_EXT_ZIFENCEI
|
||||
# Workaround mul instruction bug, see:
|
||||
# https://www.ite.com.tw/uploads/product_download/it81202-bx-chip-errata.pdf
|
||||
select RISCV_ISA_EXT_M if !(SOC_IT81302_BX || SOC_IT81202_BX)
|
||||
select RISCV_ISA_EXT_A
|
||||
select RISCV_ISA_EXT_C
|
||||
|
||||
config SOC_IT8XXX2_REG_SET_V1
|
||||
bool
|
||||
help
|
||||
This option is selected by a variable of which soc, and will
|
||||
determine the register for the IT81xx2 specification.
|
||||
|
||||
config SOC_IT8XXX2_REG_SET_V2
|
||||
bool
|
||||
help
|
||||
This option is selected by a variable of which soc, and will
|
||||
determine the register for the IT82xx2 specification.
|
||||
|
||||
config SOC_IT81302_BX
|
||||
select SOC_IT8XXX2_REG_SET_V1
|
||||
|
||||
config SOC_IT81202_BX
|
||||
select SOC_IT8XXX2_REG_SET_V1
|
||||
|
||||
config SOC_IT81302_CX
|
||||
select SOC_IT8XXX2_REG_SET_V1
|
||||
|
||||
config SOC_IT81202_CX
|
||||
select SOC_IT8XXX2_REG_SET_V1
|
||||
|
||||
config SOC_IT82202_AX
|
||||
select SOC_IT8XXX2_REG_SET_V2
|
||||
select SOC_IT8XXX2_EC_BUS_24MHZ if !DT_HAS_ITE_IT82XX2_USB_ENABLED
|
||||
|
||||
config SOC_IT82302_AX
|
||||
select SOC_IT8XXX2_REG_SET_V2
|
||||
select SOC_IT8XXX2_EC_BUS_24MHZ if !DT_HAS_ITE_IT82XX2_USB_ENABLED
|
||||
|
||||
config SOC_IT82002_AW
|
||||
select SOC_IT8XXX2_REG_SET_V2
|
||||
select SOC_IT8XXX2_EC_BUS_24MHZ if !DT_HAS_ITE_IT82XX2_USB_ENABLED
|
||||
|
||||
config SOC_IT8XXX2_PLL_FLASH_48M
|
||||
bool "Flash frequency is 48MHz"
|
||||
default y
|
||||
select FLASH
|
||||
help
|
||||
Change frequency of PLL, CPU, and flash to 48MHz during initialization.
|
||||
|
||||
Set n to use the default settings.
|
||||
(PLL and CPU run at 48MHz, flash frequency is 16MHz)
|
||||
|
||||
config SOC_IT8XXX2_GPIO_GROUP_K_L_DEFAULT_PULL_DOWN
|
||||
bool "The pins of GPIO group K and L aren't bonding with pad"
|
||||
default y
|
||||
help
|
||||
On IT81202 (128-pins package), the pins of GPIO group K and L aren't
|
||||
bonding with pad. So we configure these pins as internal pull-down
|
||||
at default to prevent leakage current due to floating.
|
||||
|
||||
config SOC_IT8XXX2_GPIO_H7_DEFAULT_OUTPUT_LOW
|
||||
bool "The GPIOH7 isn't bonding with pad and is left floating internally"
|
||||
default y
|
||||
help
|
||||
On IT81202/IT81302, the GPIOH7 isn't bonding with pad and is left
|
||||
floating internally. We need to enable internal pull-down for the pin
|
||||
to prevent leakage current, but IT81202/IT81302 doesn't have the
|
||||
capability to pull it down. We can only set it as output low,
|
||||
so we enable output low for it at initialization to prevent leakage.
|
||||
|
||||
config SOC_IT8XXX2_CPU_IDLE_GATING
|
||||
bool
|
||||
help
|
||||
This option determines whether the entering CPU idle mode can be
|
||||
gated by individual drivers. When this option is disabled, CPU idle
|
||||
mode is always permitted.
|
||||
|
||||
config SOC_IT8XXX2_EC_BUS_24MHZ
|
||||
bool "EC bus is 24MHz"
|
||||
help
|
||||
Raise EC bus to 24MHz (default is 8MHz).
|
||||
This reduces read/write EC registers latency by 50%.
|
||||
NOTE: There is limitation to enabling this config on it81xx2 series.
|
||||
The clock_frequency of ite,it8xxx2-i2c node (i2c0, i2c1, and i2c2) will
|
||||
be fixed at 400KHz.
|
||||
|
||||
choice
|
||||
prompt "Clock source for PLL reference clock"
|
||||
|
||||
config SOC_IT8XXX2_INT_32K
|
||||
bool "Use the +/-2.3% internal clock generator"
|
||||
|
||||
config SOC_IT8XXX2_EXT_32K
|
||||
bool "Use external 32.768 kHz clock source"
|
||||
|
||||
endchoice
|
||||
|
||||
config SOC_IT8XXX2_USE_ILM
|
||||
bool
|
||||
default y
|
||||
help
|
||||
If enabled, Instruction Local Memory (ILM) will be configured to execute
|
||||
code placed in the .__ram_code section out of RAM. This consumes RAM in
|
||||
blocks of 4 kilobytes, but performance of code in ILM is much more
|
||||
predictable than executing from Flash directly, and some code (such as code
|
||||
that writes to the internal Flash) must execute out of RAM.
|
||||
|
||||
config SOC_IT8XXX2_EXCEPTIONS_IN_RAM
|
||||
bool "Place exception handling code in RAM"
|
||||
default y
|
||||
select SOC_IT8XXX2_USE_ILM
|
||||
help
|
||||
Place exception handling (ISR entry/exit and related) code in ILM, which
|
||||
has more reliable performance characteristics than executing directly from
|
||||
Flash. This can significantly improve performance when under I-cache
|
||||
pressure.
|
||||
|
||||
config SOC_IT8XXX2_SHA256_HW_ACCELERATE
|
||||
bool "HW SHA256 calculation"
|
||||
help
|
||||
IT8XXX2 HW support sha256 calculation, and its calculation is faster than FW.
|
||||
We place SHA256 message, hash and key data (total 512bytes) in RAM.
|
||||
If we enable this config, because HW limits, the sha256 data must place in
|
||||
first 4KB of RAM.
|
||||
|
||||
DT_CHOSEN_ZEPHYR_FLASH := zephyr,flash
|
||||
|
||||
config SOC_IT8XXX2_FLASH_SIZE_BYTES
|
||||
hex
|
||||
default $(dt_chosen_reg_size_hex,$(DT_CHOSEN_ZEPHYR_FLASH))
|
||||
help
|
||||
Total size of writable flash.
|
||||
|
||||
config ILM_MAX_SIZE
|
||||
int "ILM Size in kB"
|
||||
default 60 if SOC_IT81202_CX || SOC_IT81302_CX
|
||||
default SRAM_SIZE
|
||||
|
||||
endif # SOC_SERIES_ITE_IT8XXX2
|
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it81202bx
Normal file
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it81202bx
Normal file
|
@ -0,0 +1,9 @@
|
|||
# Copyright (c) 2022 ITE Corporation.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_IT81202_BX
|
||||
|
||||
config SOC_IT8XXX2_GPIO_GROUP_K_L_DEFAULT_PULL_DOWN
|
||||
default y
|
||||
|
||||
endif
|
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it81202cx
Normal file
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it81202cx
Normal file
|
@ -0,0 +1,9 @@
|
|||
# Copyright (c) 2022 ITE Corporation.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_IT81202_CX
|
||||
|
||||
config SOC_IT8XXX2_GPIO_GROUP_K_L_DEFAULT_PULL_DOWN
|
||||
default y
|
||||
|
||||
endif
|
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it81302bx
Normal file
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it81302bx
Normal file
|
@ -0,0 +1,9 @@
|
|||
# Copyright (c) 2022 ITE Corporation.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_IT81302_BX
|
||||
|
||||
config SOC_IT8XXX2_GPIO_GROUP_K_L_DEFAULT_PULL_DOWN
|
||||
default n
|
||||
|
||||
endif
|
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it81302cx
Normal file
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it81302cx
Normal file
|
@ -0,0 +1,9 @@
|
|||
# Copyright (c) 2022 ITE Corporation.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_IT81302_CX
|
||||
|
||||
config SOC_IT8XXX2_GPIO_GROUP_K_L_DEFAULT_PULL_DOWN
|
||||
default n
|
||||
|
||||
endif
|
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it82002aw
Normal file
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it82002aw
Normal file
|
@ -0,0 +1,9 @@
|
|||
# Copyright (c) 2023 ITE Corporation.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_IT82002_AW
|
||||
|
||||
config SOC_IT8XXX2_GPIO_GROUP_K_L_DEFAULT_PULL_DOWN
|
||||
default y
|
||||
|
||||
endif
|
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it82202ax
Normal file
9
soc/ite/ec/it8xxx2/Kconfig.defconfig.it82202ax
Normal file
|
@ -0,0 +1,9 @@
|
|||
# Copyright (c) 2023 ITE Corporation.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_IT82202_AX
|
||||
|
||||
config SOC_IT8XXX2_GPIO_GROUP_K_L_DEFAULT_PULL_DOWN
|
||||
default y
|
||||
|
||||
endif
|
56
soc/ite/ec/it8xxx2/Kconfig.defconfig.series
Normal file
56
soc/ite/ec/it8xxx2/Kconfig.defconfig.series
Normal file
|
@ -0,0 +1,56 @@
|
|||
# Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
if SOC_SERIES_ITE_IT8XXX2
|
||||
|
||||
config RISCV_GP
|
||||
default y
|
||||
|
||||
config ARCH_HAS_CUSTOM_BUSY_WAIT
|
||||
default y
|
||||
|
||||
config SYS_CLOCK_HW_CYCLES_PER_SEC
|
||||
default 32768
|
||||
|
||||
config SYS_CLOCK_TICKS_PER_SEC
|
||||
default 4096
|
||||
|
||||
config UART_NS16550_WA_ISR_REENABLE_INTERRUPT
|
||||
default y
|
||||
depends on UART_NS16550
|
||||
|
||||
config FLASH_INIT_PRIORITY
|
||||
default 0
|
||||
|
||||
config IT8XXX2_PLL_SEQUENCE_PRIORITY
|
||||
int
|
||||
default 1
|
||||
depends on SOC_IT8XXX2_PLL_FLASH_48M
|
||||
|
||||
config VCMP_IT8XXX2_INIT_PRIORITY
|
||||
default 91 if VCMP_IT8XXX2_WORKQUEUE
|
||||
|
||||
config PINCTRL
|
||||
default y
|
||||
|
||||
config NUM_IRQS
|
||||
default 185
|
||||
|
||||
config DYNAMIC_INTERRUPTS
|
||||
default y
|
||||
|
||||
config GEN_ISR_TABLES
|
||||
default y
|
||||
|
||||
config GEN_IRQ_START_VECTOR
|
||||
default 0
|
||||
|
||||
config GEN_SW_ISR_TABLE
|
||||
default y
|
||||
|
||||
config RISCV_SOC_INTERRUPT_INIT
|
||||
default y
|
||||
|
||||
rsource "Kconfig.defconfig.it8*"
|
||||
|
||||
endif # SOC_SERIES_ITE_IT8XXX2
|
52
soc/ite/ec/it8xxx2/Kconfig.soc
Normal file
52
soc/ite/ec/it8xxx2/Kconfig.soc
Normal file
|
@ -0,0 +1,52 @@
|
|||
# Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
# SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
config SOC_SERIES_ITE_IT8XXX2
|
||||
bool
|
||||
select SOC_FAMILY_ITE_EC
|
||||
help
|
||||
Enable support for ITE IT8XXX2
|
||||
|
||||
config SOC_IT8XXX2
|
||||
bool
|
||||
select SOC_SERIES_ITE_IT8XXX2
|
||||
|
||||
config SOC_IT81302_BX
|
||||
bool
|
||||
select SOC_IT8XXX2
|
||||
|
||||
config SOC_IT81202_BX
|
||||
bool
|
||||
select SOC_IT8XXX2
|
||||
|
||||
config SOC_IT81302_CX
|
||||
bool
|
||||
select SOC_IT8XXX2
|
||||
|
||||
config SOC_IT81202_CX
|
||||
bool
|
||||
select SOC_IT8XXX2
|
||||
|
||||
config SOC_IT82202_AX
|
||||
bool
|
||||
select SOC_IT8XXX2
|
||||
|
||||
config SOC_IT82302_AX
|
||||
bool
|
||||
select SOC_IT8XXX2
|
||||
|
||||
config SOC_IT82002_AW
|
||||
bool
|
||||
select SOC_IT8XXX2
|
||||
|
||||
config SOC_SERIES
|
||||
default "it8xxx2" if SOC_SERIES_ITE_IT8XXX2
|
||||
|
||||
config SOC
|
||||
default "it81202bx" if SOC_IT81202_BX
|
||||
default "it81202cx" if SOC_IT81202_CX
|
||||
default "it81302bx" if SOC_IT81302_BX
|
||||
default "it81302cx" if SOC_IT81302_CX
|
||||
default "it82002aw" if SOC_IT82002_AW
|
||||
default "it82202ax" if SOC_IT82202_AX
|
||||
default "it82302ax" if SOC_IT82302_AX
|
50
soc/ite/ec/it8xxx2/__arithmetic.S
Normal file
50
soc/ite/ec/it8xxx2/__arithmetic.S
Normal file
|
@ -0,0 +1,50 @@
|
|||
/*
|
||||
* Copyright (c) 2022 ITE Corporation.
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
* When the 'M' extension is disabled, compiler can not recognize div/mul
|
||||
* instructions. So mul/div instructions in the below integer arithmetic
|
||||
* routines are hard coded by opcodes.
|
||||
*
|
||||
* IMPORTANT:
|
||||
* The workaround requires the nop instruction, please don't optimize it.
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_SOC_IT8XXX2_USE_ILM
|
||||
#define SECTION .__ram_code.arithmetic.
|
||||
#else
|
||||
#define SECTION .text.it8xxx2.arithmetic.
|
||||
#endif
|
||||
|
||||
.macro __int_arithmetic func opcode
|
||||
.section SECTION\func
|
||||
.align 2
|
||||
.globl \func
|
||||
.type \func, @function
|
||||
\func:
|
||||
.word \opcode
|
||||
nop
|
||||
ret
|
||||
.size \func, .-\func
|
||||
.endm
|
||||
|
||||
/* signed 32 bit multiplication. opcode of mul a0,a0,a1 is 0x02b50533 */
|
||||
__int_arithmetic __mulsi3 0x02b50533
|
||||
|
||||
/* signed 32 bit division. opcode of div a0,a0,a1 is 0x02b54533 */
|
||||
__int_arithmetic __divsi3 0x02b54533
|
||||
|
||||
/* unsigned 32 bit division. opcode of divu a0,a0,a1 is 0x02b55533 */
|
||||
__int_arithmetic __udivsi3 0x02b55533
|
||||
|
||||
/*
|
||||
* This function return the remainder of the signed division.
|
||||
* opcode of rem a0,a0,a1 is 0x02b56533
|
||||
*/
|
||||
__int_arithmetic __modsi3 0x02b56533
|
||||
|
||||
/*
|
||||
* This function return the remainder of the unsigned division.
|
||||
* opcode of remu a0,a0,a1 is 0x02b57533
|
||||
*/
|
||||
__int_arithmetic __umodsi3 0x02b57533
|
211
soc/ite/ec/it8xxx2/ilm.c
Normal file
211
soc/ite/ec/it8xxx2/ilm.c
Normal file
|
@ -0,0 +1,211 @@
|
|||
/*
|
||||
* Copyright 2022 The ChromiumOS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
|
||||
#include <zephyr/device.h>
|
||||
#include <zephyr/devicetree.h>
|
||||
#include <zephyr/irq.h>
|
||||
#include <zephyr/logging/log.h>
|
||||
#include <zephyr/sys/__assert.h>
|
||||
|
||||
LOG_MODULE_REGISTER(soc_it8xxx2_ilm, CONFIG_LOG_DEFAULT_LEVEL);
|
||||
|
||||
/*
|
||||
* Instruction Local Memory (ILM) support for IT8xxx2.
|
||||
*
|
||||
* IT8xxx2 allows 4-kilobyte blocks of RAM be configured individually as either Instruction- or
|
||||
* Data Local Memory (ILM or DLM). Addresses from which instructions will be fetched by the CPU
|
||||
* *must* be in the Flash memory space: it is not permitted to execute from RAM addresses, only
|
||||
* through ILM mappings into RAM.
|
||||
*
|
||||
* When a RAM block is configured as ILM, accesses to addresses matching the corresponding Scratch
|
||||
* SRAM address register (SCARn{H,M,L}) are redirected to the corresponding ILM block in RAM.
|
||||
* If SCAR0 (corresponding to ILM0) has the value 0x8021532 and ILM0 is enabled, then instruction
|
||||
* fetches from the memory range 0x8021532..0x8022532 will be redirected to physical addresses
|
||||
* 0x80100000..0x80101000 (the first 4k block of RAM).
|
||||
*
|
||||
* Instruction fetch from Flash is normally cacheable, but configuring ILM for a region makes that
|
||||
* address range non-cacheable (which is appropriate because Flash has high latency but RAM is
|
||||
* essentially the same speed as cache).
|
||||
*/
|
||||
|
||||
extern const uint8_t __ilm_flash_start[];
|
||||
extern const uint8_t __ilm_flash_end[];
|
||||
extern uint8_t __ilm_ram_start[];
|
||||
extern uint8_t __ilm_ram_end[];
|
||||
|
||||
#define ILM_BLOCK_SIZE 0x1000
|
||||
BUILD_ASSERT((ILM_BLOCK_SIZE & (ILM_BLOCK_SIZE - 1)) == 0, "ILM_BLOCK_SIZE must be a power of two");
|
||||
|
||||
#define FLASH_BASE CONFIG_FLASH_BASE_ADDRESS
|
||||
#define RAM_BASE CONFIG_SRAM_BASE_ADDRESS
|
||||
|
||||
#define ILM_NODE DT_NODELABEL(ilm)
|
||||
|
||||
#define SCARH_ENABLE BIT(3)
|
||||
#define SCARH_ADDR_BIT19 BIT(7)
|
||||
|
||||
/*
|
||||
* SCAR registers contain 20-bit addresses in three registers, with one set
|
||||
* of SCAR registers for each ILM block that may be configured.
|
||||
*/
|
||||
struct scar_reg {
|
||||
/* Bits 0..7 of address; SCARnL */
|
||||
uint8_t l;
|
||||
/* Bits 8..15 of address; SCARnM */
|
||||
uint8_t m;
|
||||
/* Bits 16..18 and 19 of address, plus the enable bit for the entire SCAR; SCARnH */
|
||||
uint8_t h;
|
||||
};
|
||||
|
||||
struct ilm_config {
|
||||
volatile struct scar_reg *scar_regs[CONFIG_ILM_MAX_SIZE / 4];
|
||||
};
|
||||
|
||||
bool it8xxx2_is_ilm_configured(void)
|
||||
{
|
||||
return device_is_ready(DEVICE_DT_GET(ILM_NODE));
|
||||
}
|
||||
|
||||
static bool __maybe_unused is_block_aligned(const void *const p)
|
||||
{
|
||||
return ((uintptr_t)p & (ILM_BLOCK_SIZE - 1)) == 0;
|
||||
}
|
||||
|
||||
static int it8xxx2_configure_ilm_block(const struct ilm_config *const config, void *ram_addr,
|
||||
const void *flash_addr, const size_t copy_sz)
|
||||
{
|
||||
if ((uintptr_t)ram_addr < RAM_BASE) {
|
||||
return -EFAULT; /* Not in RAM */
|
||||
}
|
||||
const int dirmap_index = ((uintptr_t)ram_addr - RAM_BASE) / ILM_BLOCK_SIZE;
|
||||
|
||||
if (dirmap_index >= ARRAY_SIZE(config->scar_regs)) {
|
||||
return -EFAULT; /* Past the end of RAM */
|
||||
}
|
||||
BUILD_ASSERT((FLASH_BASE & GENMASK(19, 0)) == 0,
|
||||
"Flash is assumed to be aligned to SCAR register width");
|
||||
if (((uintptr_t)flash_addr - FLASH_BASE) & ~GENMASK(19, 0)) {
|
||||
return -EFAULT; /* Address doesn't fit in the SCAR */
|
||||
}
|
||||
if (!is_block_aligned(flash_addr)) {
|
||||
/* Bits 0..11 of SCAR can be programmed but ILM only works if they're zero */
|
||||
return -EFAULT;
|
||||
}
|
||||
|
||||
LOG_DBG("Enabling ILM%d %p -> %p, copy %d", dirmap_index, flash_addr, ram_addr, copy_sz);
|
||||
|
||||
volatile struct scar_reg *const scar = config->scar_regs[dirmap_index];
|
||||
|
||||
int irq_key = irq_lock();
|
||||
|
||||
/* Ensure scratch RAM for block data access is enabled */
|
||||
scar->h = SCARH_ENABLE;
|
||||
/* Copy block contents from flash into RAM */
|
||||
memcpy(ram_addr, flash_addr, copy_sz);
|
||||
/* Program SCAR */
|
||||
scar->l = (uintptr_t)flash_addr & GENMASK(7, 0);
|
||||
scar->m = ((uintptr_t)flash_addr & GENMASK(15, 8)) >> 8;
|
||||
|
||||
uint8_t scarh_value = ((uintptr_t)flash_addr & GENMASK(18, 16)) >> 16;
|
||||
|
||||
if ((uintptr_t)flash_addr & BIT(19)) {
|
||||
scarh_value |= SCARH_ADDR_BIT19;
|
||||
}
|
||||
scar->h = scarh_value;
|
||||
|
||||
irq_unlock(irq_key);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int it8xxx2_ilm_init(const struct device *dev)
|
||||
{
|
||||
/* Invariants enforced by the linker script */
|
||||
__ASSERT(is_block_aligned(__ilm_ram_start),
|
||||
"ILM physical base address (%p) must be 4k-aligned", __ilm_ram_start);
|
||||
__ASSERT(is_block_aligned(__ilm_flash_start),
|
||||
"ILM flash base address (%p) must be 4k-aligned", __ilm_flash_start);
|
||||
__ASSERT_NO_MSG((uintptr_t)__ilm_ram_end >= (uintptr_t)__ilm_ram_start &&
|
||||
(uintptr_t)__ilm_flash_end >= (uintptr_t)__ilm_flash_start);
|
||||
|
||||
LOG_DBG("ILM init %p-%p -> %p-%p", __ilm_flash_start, __ilm_flash_end, __ilm_ram_start,
|
||||
__ilm_ram_end);
|
||||
for (uintptr_t block_base = (uintptr_t)__ilm_ram_start;
|
||||
block_base < (uintptr_t)__ilm_ram_end; block_base += ILM_BLOCK_SIZE) {
|
||||
uintptr_t flash_base =
|
||||
(uintptr_t)__ilm_flash_start + (block_base - (uintptr_t)__ilm_ram_start);
|
||||
/*
|
||||
* Part of the target RAM block might be used for non-code data; avoid overwriting
|
||||
* it by only copying as much data as the ILM flash region contains.
|
||||
*/
|
||||
size_t used_size = MIN((uintptr_t)__ilm_flash_end - flash_base, ILM_BLOCK_SIZE);
|
||||
int rv = it8xxx2_configure_ilm_block(dev->config, (void *)block_base,
|
||||
(const void *)flash_base, used_size);
|
||||
|
||||
if (rv) {
|
||||
LOG_ERR("Unable to configure ILM block %p: %d", (void *)flash_base, rv);
|
||||
return rv;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
#define SCAR_REG(n) (volatile struct scar_reg *)DT_REG_ADDR_BY_IDX(ILM_NODE, n)
|
||||
|
||||
static const struct ilm_config ilm_config = {
|
||||
.scar_regs = {
|
||||
/* SCAR0 SRAM 4KB */
|
||||
SCAR_REG(0),
|
||||
SCAR_REG(1),
|
||||
SCAR_REG(2),
|
||||
SCAR_REG(3),
|
||||
SCAR_REG(4),
|
||||
SCAR_REG(5),
|
||||
SCAR_REG(6),
|
||||
SCAR_REG(7),
|
||||
SCAR_REG(8),
|
||||
SCAR_REG(9),
|
||||
SCAR_REG(10),
|
||||
SCAR_REG(11),
|
||||
SCAR_REG(12),
|
||||
SCAR_REG(13),
|
||||
SCAR_REG(14),
|
||||
/*
|
||||
* Except for CONFIG_SOC_IT81202_CX and CONFIG_SOC_IT81302_CX
|
||||
* maximum ILM size are 60KB, the ILM size of other varients
|
||||
* are equal to the SRAM size.
|
||||
*/
|
||||
#if (CONFIG_ILM_MAX_SIZE == 256)
|
||||
/* SCAR15 SRAM 4KB */
|
||||
SCAR_REG(15),
|
||||
/* SCAR16 SRAM 16KB */
|
||||
SCAR_REG(16), SCAR_REG(16), SCAR_REG(16), SCAR_REG(16),
|
||||
/* SCAR17 SRAM 16KB */
|
||||
SCAR_REG(17), SCAR_REG(17), SCAR_REG(17), SCAR_REG(17),
|
||||
/* SCAR18 SRAM 16KB */
|
||||
SCAR_REG(18), SCAR_REG(18), SCAR_REG(18), SCAR_REG(18),
|
||||
/* SCAR19 SRAM 16KB */
|
||||
SCAR_REG(19), SCAR_REG(19), SCAR_REG(19), SCAR_REG(19),
|
||||
/* SCAR20 SRAM 32KB */
|
||||
SCAR_REG(20), SCAR_REG(20), SCAR_REG(20), SCAR_REG(20),
|
||||
SCAR_REG(20), SCAR_REG(20), SCAR_REG(20), SCAR_REG(20),
|
||||
/* SCAR21 SRAM 32KB */
|
||||
SCAR_REG(21), SCAR_REG(21), SCAR_REG(21), SCAR_REG(21),
|
||||
SCAR_REG(21), SCAR_REG(21), SCAR_REG(21), SCAR_REG(21),
|
||||
/* SCAR22 SRAM 32KB */
|
||||
SCAR_REG(22), SCAR_REG(22), SCAR_REG(22), SCAR_REG(22),
|
||||
SCAR_REG(22), SCAR_REG(22), SCAR_REG(22), SCAR_REG(22),
|
||||
/* SCAR23 SRAM 32KB */
|
||||
SCAR_REG(23), SCAR_REG(23), SCAR_REG(23), SCAR_REG(23),
|
||||
SCAR_REG(23), SCAR_REG(23), SCAR_REG(23), SCAR_REG(23)
|
||||
#endif
|
||||
}};
|
||||
BUILD_ASSERT(ARRAY_SIZE(ilm_config.scar_regs) * ILM_BLOCK_SIZE == KB(CONFIG_ILM_MAX_SIZE),
|
||||
"Wrong number of SCAR registers defined for RAM size");
|
||||
|
||||
DEVICE_DT_DEFINE(ILM_NODE, &it8xxx2_ilm_init, NULL, NULL, &ilm_config, PRE_KERNEL_1, 0, NULL);
|
15
soc/ite/ec/it8xxx2/ilm.h
Normal file
15
soc/ite/ec/it8xxx2/ilm.h
Normal file
|
@ -0,0 +1,15 @@
|
|||
/*
|
||||
* Copyright 2022 The ChromiumOS Authors.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#include <stdbool.h>
|
||||
|
||||
/* Places code in the section that gets mapped into ILM */
|
||||
#define __soc_ram_code __attribute__((section(".__ram_code")))
|
||||
|
||||
|
||||
#ifndef _ASMLANGUAGE
|
||||
bool it8xxx2_is_ilm_configured(void);
|
||||
#endif
|
424
soc/ite/ec/it8xxx2/linker.ld
Normal file
424
soc/ite/ec/it8xxx2/linker.ld
Normal file
|
@ -0,0 +1,424 @@
|
|||
/*
|
||||
* Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
#include <soc.h>
|
||||
#include <zephyr/devicetree.h>
|
||||
|
||||
#include <zephyr/linker/sections.h>
|
||||
#include <zephyr/linker/devicetree_regions.h>
|
||||
|
||||
#include <zephyr/linker/linker-defs.h>
|
||||
#include <zephyr/linker/linker-tool.h>
|
||||
|
||||
#ifdef CONFIG_XIP
|
||||
#define ROMABLE_REGION ROM
|
||||
#else
|
||||
#define ROMABLE_REGION RAM
|
||||
#endif
|
||||
#define RAMABLE_REGION RAM
|
||||
|
||||
#define _EXCEPTION_SECTION_NAME exceptions
|
||||
#define _RESET_SECTION_NAME reset
|
||||
|
||||
#ifdef CONFIG_XIP
|
||||
#if DT_NODE_HAS_COMPAT_STATUS(DT_CHOSEN(zephyr_flash), soc_nv_flash, okay)
|
||||
#ifdef CONFIG_FLASH_LOAD_OFFSET
|
||||
#define ROM_BASE (DT_REG_ADDR(DT_CHOSEN(zephyr_flash)) + \
|
||||
CONFIG_FLASH_LOAD_OFFSET)
|
||||
#else /* !CONFIG_FLASH_LOAD_OFFSET */
|
||||
#define ROM_BASE DT_REG_ADDR(DT_CHOSEN(zephyr_flash))
|
||||
#endif /* CONFIG_FLASH_LOAD_OFFSET */
|
||||
#define ROM_SIZE DT_REG_SIZE(DT_CHOSEN(zephyr_flash))
|
||||
#elif DT_NODE_HAS_COMPAT(DT_CHOSEN(zephyr_flash), jedec_spi_nor)
|
||||
/* For jedec,spi-nor we expect the spi controller to memory map the flash
|
||||
* and for that mapping to be the second register property of the spi
|
||||
* controller.
|
||||
*/
|
||||
#define SPI_CTRL DT_PARENT(DT_CHOSEN(zephyr_flash))
|
||||
#define ROM_BASE DT_REG_ADDR_BY_IDX(SPI_CTRL, 1)
|
||||
#define ROM_SIZE DT_REG_SIZE_BY_IDX(SPI_CTRL, 1)
|
||||
#endif
|
||||
#else /* CONFIG_XIP */
|
||||
#define ROM_BASE CONFIG_SRAM_BASE_ADDRESS
|
||||
#define ROM_SIZE KB(CONFIG_SRAM_SIZE)
|
||||
#endif /* CONFIG_XIP */
|
||||
|
||||
#define RAM_BASE CONFIG_SRAM_BASE_ADDRESS
|
||||
#define RAM_SIZE KB(CONFIG_SRAM_SIZE)
|
||||
|
||||
#ifdef CONFIG_RISCV_PMP
|
||||
#define MPU_MIN_SIZE 4
|
||||
#define MPU_MIN_SIZE_ALIGN . = ALIGN(MPU_MIN_SIZE);
|
||||
#if defined(CONFIG_MPU_REQUIRES_POWER_OF_TWO_ALIGNMENT)
|
||||
#define MPU_ALIGN(region_size) \
|
||||
. = ALIGN(MPU_MIN_SIZE); \
|
||||
. = ALIGN( 1 << LOG2CEIL(region_size))
|
||||
#else
|
||||
#define MPU_ALIGN(region_size) \
|
||||
. = ALIGN(MPU_MIN_SIZE)
|
||||
#endif
|
||||
#else
|
||||
#define MPU_MIN_SIZE_ALIGN
|
||||
#define MPU_ALIGN(region_size) . = ALIGN(4)
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_SOC_IT8XXX2_SHA256_HW_ACCELERATE
|
||||
#define SHA256_BLOCK_SIZE 0x200
|
||||
#endif
|
||||
|
||||
#include <zephyr/linker/linker-devnull.h>
|
||||
|
||||
MEMORY
|
||||
{
|
||||
#ifdef CONFIG_XIP
|
||||
ROM (rx) : ORIGIN = ROM_BASE, LENGTH = ROM_SIZE
|
||||
#endif
|
||||
RAM (rwx) : ORIGIN = RAM_BASE, LENGTH = RAM_SIZE
|
||||
|
||||
#if defined(CONFIG_LINKER_DEVNULL_MEMORY)
|
||||
DEVNULL_ROM (rx) : ORIGIN = DEVNULL_ADDR, LENGTH = DEVNULL_SIZE
|
||||
#endif
|
||||
|
||||
LINKER_DT_REGIONS()
|
||||
|
||||
/* Used by and documented in include/linker/intlist.ld */
|
||||
IDT_LIST (wx) : ORIGIN = 0xFFFFF7FF, LENGTH = 2K
|
||||
}
|
||||
|
||||
ENTRY(CONFIG_KERNEL_ENTRY)
|
||||
|
||||
SECTIONS
|
||||
{
|
||||
|
||||
#include <zephyr/linker/rel-sections.ld>
|
||||
|
||||
/*
|
||||
* The .plt and .iplt are here according to
|
||||
* 'riscv32-zephyr-elf-ld --verbose', before text section.
|
||||
*/
|
||||
SECTION_PROLOGUE(.plt,,)
|
||||
{
|
||||
*(.plt)
|
||||
}
|
||||
|
||||
SECTION_PROLOGUE(.iplt,,)
|
||||
{
|
||||
*(.iplt)
|
||||
}
|
||||
|
||||
GROUP_START(ROMABLE_REGION)
|
||||
__rom_region_start = ROM_BASE;
|
||||
|
||||
SECTION_PROLOGUE(rom_start,,)
|
||||
{
|
||||
. = ALIGN(16);
|
||||
/* Located in generated directory. This file is populated by calling
|
||||
* zephyr_linker_sources(ROM_START ...).
|
||||
*/
|
||||
#include <snippets-rom-start.ld>
|
||||
} GROUP_LINK_IN(ROMABLE_REGION)
|
||||
|
||||
#ifdef CONFIG_CODE_DATA_RELOCATION
|
||||
#include <linker_relocate.ld>
|
||||
#endif
|
||||
|
||||
SECTION_PROLOGUE(_RESET_SECTION_NAME,,)
|
||||
{
|
||||
KEEP(*(.reset.*))
|
||||
} GROUP_LINK_IN(ROMABLE_REGION)
|
||||
|
||||
#ifndef CONFIG_SOC_IT8XXX2_EXCEPTIONS_IN_RAM
|
||||
SECTION_PROLOGUE(_EXCEPTION_SECTION_NAME,,)
|
||||
{
|
||||
KEEP(*(".exception.entry.*"))
|
||||
*(".exception.other.*")
|
||||
} GROUP_LINK_IN(ROMABLE_REGION)
|
||||
#endif
|
||||
|
||||
SECTION_PROLOGUE(_TEXT_SECTION_NAME,,)
|
||||
{
|
||||
. = ALIGN(4);
|
||||
KEEP(*(.openocd_debug))
|
||||
KEEP(*(".openocd_debug.*"))
|
||||
|
||||
__text_region_start = .;
|
||||
|
||||
*(.text)
|
||||
*(".text.*")
|
||||
*(.gnu.linkonce.t.*)
|
||||
#include <zephyr/linker/kobject-text.ld>
|
||||
|
||||
/* IT8xxx2 requires memory mappings be configured for execution
|
||||
* out of RAM, which refer to contiguous blocks of RAM. Place
|
||||
* all relevant sections together to minimize RAM waste. */
|
||||
. = ALIGN(0x1000);
|
||||
/* Mapping base address must be 4k-aligned */
|
||||
__ilm_flash_start = .;
|
||||
#ifdef CONFIG_SOC_IT8XXX2_SHA256_HW_ACCELERATE
|
||||
/* Pad to match allocation of block in RAM,
|
||||
* maintaining code alignment against ILM */
|
||||
__sha256_pad_block_start = .;
|
||||
. = . + SHA256_BLOCK_SIZE;
|
||||
#endif
|
||||
/* Specially-tagged functions in SoC sources */
|
||||
KEEP(*(.__ram_code))
|
||||
*(.__ram_code.*)
|
||||
#ifdef CONFIG_SOC_IT8XXX2_EXCEPTIONS_IN_RAM
|
||||
KEEP(*(".exception.entry.*"))
|
||||
*(".exception.other.*")
|
||||
#endif
|
||||
__ilm_flash_end = .;
|
||||
/* ILM mapping is always a multiple of 4k size; ensure following
|
||||
* sections won't incorrectly redirect to RAM. */
|
||||
. = ALIGN(0x1000);
|
||||
|
||||
} GROUP_LINK_IN(ROMABLE_REGION)
|
||||
|
||||
__text_region_end = .;
|
||||
|
||||
__rodata_region_start = .;
|
||||
#include <zephyr/linker/common-rom.ld>
|
||||
#include <zephyr/linker/thread-local-storage.ld>
|
||||
|
||||
SECTION_PROLOGUE(_RODATA_SECTION_NAME,,)
|
||||
{
|
||||
. = ALIGN(4);
|
||||
*(.srodata)
|
||||
*(".srodata.*")
|
||||
*(.rodata)
|
||||
*(".rodata.*")
|
||||
*(.gnu.linkonce.r.*)
|
||||
*(.sdata2 .sdata2.* .gnu.linkonce.s2.*)
|
||||
|
||||
/* Located in generated directory. This file is populated by the
|
||||
* zephyr_linker_sources() Cmake function.
|
||||
*/
|
||||
#include <snippets-rodata.ld>
|
||||
#include <zephyr/linker/kobject-rom.ld>
|
||||
. = ALIGN(4);
|
||||
} GROUP_LINK_IN(ROMABLE_REGION)
|
||||
|
||||
#include <zephyr/linker/cplusplus-rom.ld>
|
||||
__rodata_region_end = .;
|
||||
|
||||
/* For non-XIP system, __rom_region_end symbol should be set to
|
||||
* the end of common ROMABLE_REGIONs (text and rodata) instead of
|
||||
* the linker script end, so it wouldn't mistakenly contain
|
||||
* RAMABLE_REGION in it.
|
||||
*/
|
||||
#ifndef CONFIG_XIP
|
||||
#ifdef CONFIG_RISCV_PMP
|
||||
SECTION_PROLOGUE(rom_mpu_padding,,)
|
||||
{
|
||||
MPU_ALIGN(__rodata_region_end - __rom_region_start);
|
||||
#ifdef CONFIG_QEMU_TARGET
|
||||
/*
|
||||
* QEMU doesn't vet each instruction fetch individually.
|
||||
* Instead, it grabs a whole page and perform dynamic
|
||||
* transation on it in a batch. It therefore validates
|
||||
* PMP permissions using page-sized and -aligned chunks.
|
||||
*/
|
||||
. = ALIGN(0x1000);
|
||||
#endif
|
||||
} GROUP_LINK_IN(ROMABLE_REGION)
|
||||
#endif /* CONFIG_RISCV_PMP */
|
||||
|
||||
__rom_region_end = .;
|
||||
__rom_region_size = __rom_region_end - __rom_region_start;
|
||||
#endif /* CONFIG_XIP */
|
||||
GROUP_END(ROMABLE_REGION)
|
||||
|
||||
GROUP_START(RAMABLE_REGION)
|
||||
|
||||
. = RAM_BASE;
|
||||
|
||||
/* Claim RAM for ILM mappings; must be 4k-aligned and each mapping is 4k in
|
||||
* size, but mapped regions can still be accessed as data so don't need to be
|
||||
* padded out to 4k size. This doesn't load any sections because code in ILM
|
||||
* is still accessed at its VMA in ROM. */
|
||||
SECTION_PROLOGUE(ilm_ram,(NOLOAD),ALIGN(0x1000))
|
||||
{
|
||||
__ilm_ram_start = .;
|
||||
|
||||
#ifdef CONFIG_SOC_IT8XXX2_SHA256_HW_ACCELERATE
|
||||
__sha256_ram_block_start = .;
|
||||
KEEP(*(.__sha256_ram_block))
|
||||
__sha256_ram_block_size = \
|
||||
ABSOLUTE(. - __sha256_ram_block_start);
|
||||
__sha256_ram_block_end = .;
|
||||
ASSERT((__sha256_ram_block_size == SHA256_BLOCK_SIZE), \
|
||||
"We need 512bytes for HW sha256 module");
|
||||
ASSERT((__sha256_ram_block_end < (RAM_BASE + 0x1000)), \
|
||||
"512bytes must in SRAM first 4kbytes");
|
||||
ASSERT(((ABSOLUTE(__sha256_ram_block_start) & 0xfff) == \
|
||||
(ABSOLUTE(__sha256_pad_block_start) & 0xfff)), \
|
||||
"sha256 ram block needs the same offset with sha256 rom block");
|
||||
#endif
|
||||
. += __ilm_flash_end - __ilm_flash_start;
|
||||
__ilm_ram_end = .;
|
||||
} GROUP_LINK_IN(RAMABLE_REGION)
|
||||
|
||||
_image_ram_start = .;
|
||||
/* Located in generated directory. This file is populated by the
|
||||
* zephyr_linker_sources() Cmake function.
|
||||
*/
|
||||
#include <snippets-ram-sections.ld>
|
||||
|
||||
#if defined(CONFIG_USERSPACE)
|
||||
#define APP_SHARED_ALIGN MPU_MIN_SIZE_ALIGN
|
||||
#define SMEM_PARTITION_ALIGN MPU_ALIGN
|
||||
|
||||
#include <app_smem.ld>
|
||||
|
||||
_app_smem_size = _app_smem_end - _app_smem_start;
|
||||
_app_smem_rom_start = LOADADDR(_APP_SMEM_SECTION_NAME);
|
||||
#endif /* CONFIG_USERSPACE */
|
||||
|
||||
SECTION_DATA_PROLOGUE(_BSS_SECTION_NAME,(NOLOAD),)
|
||||
{
|
||||
MPU_MIN_SIZE_ALIGN
|
||||
/*
|
||||
* For performance, BSS section is assumed to be 4 byte aligned and
|
||||
* a multiple of 4 bytes
|
||||
*/
|
||||
. = ALIGN(4);
|
||||
__bss_start = .;
|
||||
__kernel_ram_start = .;
|
||||
*(.sbss)
|
||||
*(".sbss.*")
|
||||
*(.bss)
|
||||
*(".bss.*")
|
||||
COMMON_SYMBOLS
|
||||
|
||||
#ifdef CONFIG_CODE_DATA_RELOCATION
|
||||
#include <linker_sram_bss_relocate.ld>
|
||||
#endif
|
||||
|
||||
/*
|
||||
* As memory is cleared in words only, it is simpler to ensure the BSS
|
||||
* section ends on a 4 byte boundary. This wastes a maximum of 3 bytes.
|
||||
*/
|
||||
__bss_end = ALIGN(4);
|
||||
} GROUP_DATA_LINK_IN(RAMABLE_REGION, RAMABLE_REGION)
|
||||
|
||||
#include <zephyr/linker/common-noinit.ld>
|
||||
|
||||
SECTION_DATA_PROLOGUE(_DATA_SECTION_NAME,,)
|
||||
{
|
||||
. = ALIGN(4);
|
||||
/* _image_ram_start = .; */
|
||||
__data_region_start = .;
|
||||
__data_start = .;
|
||||
|
||||
*(.data)
|
||||
*(".data.*")
|
||||
|
||||
#ifdef CONFIG_RISCV_GP
|
||||
/*
|
||||
* RISC-V architecture has 12-bit signed immediate offsets in the
|
||||
* instructions. If we can put the most commonly accessed globals
|
||||
* in a special 4K span of memory addressed by the GP register, then
|
||||
* we can access those values in a single instruction, saving both
|
||||
* codespace and runtime.
|
||||
*
|
||||
* Since these immediate offsets are signed, place gp 0x800 past the
|
||||
* beginning of .sdata so that we can use both positive and negative
|
||||
* offsets.
|
||||
*/
|
||||
. = ALIGN(8);
|
||||
PROVIDE (__global_pointer$ = . + 0x800);
|
||||
#endif
|
||||
|
||||
*(.sdata .sdata.* .gnu.linkonce.s.*)
|
||||
|
||||
/* Located in generated directory. This file is populated by the
|
||||
* zephyr_linker_sources() Cmake function.
|
||||
*/
|
||||
#include <snippets-rwdata.ld>
|
||||
|
||||
#ifdef CONFIG_CODE_DATA_RELOCATION
|
||||
#include <linker_sram_data_relocate.ld>
|
||||
#endif
|
||||
|
||||
__data_end = .;
|
||||
|
||||
} GROUP_DATA_LINK_IN(RAMABLE_REGION, ROMABLE_REGION)
|
||||
__data_size = __data_end - __data_start;
|
||||
__data_load_start = LOADADDR(_DATA_SECTION_NAME);
|
||||
|
||||
__data_region_load_start = LOADADDR(_DATA_SECTION_NAME);
|
||||
|
||||
#include <zephyr/linker/common-ram.ld>
|
||||
#include <zephyr/linker/kobject-data.ld>
|
||||
#include <zephyr/linker/cplusplus-ram.ld>
|
||||
|
||||
/* Located in generated directory. This file is populated by the
|
||||
* zephyr_linker_sources() Cmake function.
|
||||
*/
|
||||
#include <snippets-data-sections.ld>
|
||||
|
||||
__data_region_end = .;
|
||||
|
||||
SECTION_DATA_PROLOGUE(.h2ram_pool,(NOLOAD),)
|
||||
{
|
||||
/*
|
||||
* Since __sha256_ram_block section must in the first 4KB,
|
||||
* h2ram_pool section is no longer included first inside the
|
||||
* RAMABLE_REGION.
|
||||
* Append h2ram_pool section at the end of used memory, so gap
|
||||
* due to alignment is still available for newly added variables
|
||||
*/
|
||||
. = ALIGN(0x1000);
|
||||
_h2ram_pool_start = .;
|
||||
KEEP(*(.h2ram_pool))
|
||||
_h2ram_pool_end = .;
|
||||
} GROUP_DATA_LINK_IN(RAMABLE_REGION, RAMABLE_REGION)
|
||||
_h2ram_pool_size = ABSOLUTE(_h2ram_pool_end - _h2ram_pool_start);
|
||||
|
||||
__kernel_ram_end = .;
|
||||
__kernel_ram_size = __kernel_ram_end - __kernel_ram_start;
|
||||
|
||||
/* Located in generated directory. This file is populated by the
|
||||
* zephyr_linker_sources() Cmake function.
|
||||
*/
|
||||
#include <snippets-sections.ld>
|
||||
|
||||
#define LAST_RAM_ALIGN MPU_MIN_SIZE_ALIGN
|
||||
|
||||
#include <zephyr/linker/ram-end.ld>
|
||||
|
||||
GROUP_END(RAMABLE_REGION)
|
||||
|
||||
#include <zephyr/linker/debug-sections.ld>
|
||||
|
||||
/DISCARD/ : { *(.note.GNU-stack) }
|
||||
|
||||
SECTION_PROLOGUE(.riscv.attributes, 0,)
|
||||
{
|
||||
KEEP(*(.riscv.attributes))
|
||||
KEEP(*(.gnu.attributes))
|
||||
}
|
||||
|
||||
/* Sections generated from 'zephyr,memory-region' nodes */
|
||||
LINKER_DT_SECTIONS()
|
||||
|
||||
/* Because ROMABLE_REGION != RAMABLE_REGION in XIP-system, it is valid
|
||||
* to set __rom_region_end symbol at the end of linker script and
|
||||
* doesn't mistakenly contain the RAMABLE_REGION in it.
|
||||
*/
|
||||
#ifdef CONFIG_XIP
|
||||
/* Must be last in romable region */
|
||||
SECTION_PROLOGUE(.last_section,(NOLOAD),)
|
||||
{
|
||||
} GROUP_LINK_IN(ROMABLE_REGION)
|
||||
|
||||
/* To provide the image size as a const expression,
|
||||
* calculate this value here. */
|
||||
__rom_region_end = LOADADDR(.last_section);
|
||||
__rom_region_size = __rom_region_end - __rom_region_start;
|
||||
#endif
|
||||
|
||||
}
|
400
soc/ite/ec/it8xxx2/soc.c
Normal file
400
soc/ite/ec/it8xxx2/soc.c
Normal file
|
@ -0,0 +1,400 @@
|
|||
/*
|
||||
* Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
*/
|
||||
|
||||
#include <zephyr/arch/riscv/csr.h>
|
||||
#include <zephyr/kernel.h>
|
||||
#include <zephyr/device.h>
|
||||
#include <zephyr/init.h>
|
||||
#include "ilm.h"
|
||||
#include <soc_common.h>
|
||||
#include "soc_espi.h"
|
||||
#include <zephyr/dt-bindings/interrupt-controller/ite-intc.h>
|
||||
|
||||
/*
|
||||
* This define gets the total number of USBPD ports available on the
|
||||
* ITE EC chip from dtsi (include status disable). Both it81202 and
|
||||
* it81302 support two USBPD ports.
|
||||
*/
|
||||
#define SOC_USBPD_ITE_PHY_PORT_COUNT \
|
||||
COND_CODE_1(DT_NODE_EXISTS(DT_INST(1, ite_it8xxx2_usbpd)), (2), (1))
|
||||
|
||||
/*
|
||||
* This define gets the number of active USB Power Delivery (USB PD)
|
||||
* ports in use on the ITE microcontroller from dts (only status okay).
|
||||
* The active port usage should follow the order of ITE TCPC port index,
|
||||
* ex. if we're active only one ITE USB PD port, then the port should be
|
||||
* 0x3700 (port0 register base), instead of 0x3800 (port1 register base).
|
||||
*/
|
||||
#define SOC_USBPD_ITE_ACTIVE_PORT_COUNT DT_NUM_INST_STATUS_OKAY(ite_it8xxx2_usbpd)
|
||||
|
||||
uint32_t chip_get_pll_freq(void)
|
||||
{
|
||||
uint32_t pllfreq;
|
||||
|
||||
switch (IT8XXX2_ECPM_PLLFREQR & 0x0F) {
|
||||
case 0:
|
||||
pllfreq = MHZ(8);
|
||||
break;
|
||||
case 1:
|
||||
pllfreq = MHZ(16);
|
||||
break;
|
||||
case 2:
|
||||
pllfreq = MHZ(24);
|
||||
break;
|
||||
case 3:
|
||||
pllfreq = MHZ(32);
|
||||
break;
|
||||
case 4:
|
||||
pllfreq = MHZ(48);
|
||||
break;
|
||||
case 5:
|
||||
pllfreq = MHZ(64);
|
||||
break;
|
||||
case 6:
|
||||
pllfreq = MHZ(72);
|
||||
break;
|
||||
case 7:
|
||||
pllfreq = MHZ(96);
|
||||
break;
|
||||
default:
|
||||
return -ERANGE;
|
||||
}
|
||||
|
||||
return pllfreq;
|
||||
}
|
||||
|
||||
void __soc_ram_code chip_pll_ctrl(enum chip_pll_mode mode)
|
||||
{
|
||||
volatile uint8_t _pll_ctrl __unused;
|
||||
|
||||
IT8XXX2_ECPM_PLLCTRL = mode;
|
||||
/*
|
||||
* for deep doze / sleep mode
|
||||
* This load operation will ensure PLL setting is taken into
|
||||
* control register before wait for interrupt instruction.
|
||||
*/
|
||||
_pll_ctrl = IT8XXX2_ECPM_PLLCTRL;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_SOC_IT8XXX2_PLL_FLASH_48M
|
||||
struct pll_config_t {
|
||||
uint8_t pll_freq;
|
||||
uint8_t div_fnd;
|
||||
uint8_t div_uart;
|
||||
uint8_t div_smb;
|
||||
uint8_t div_sspi;
|
||||
uint8_t div_ec;
|
||||
uint8_t div_jtag;
|
||||
uint8_t div_pwm;
|
||||
uint8_t div_usbpd;
|
||||
};
|
||||
|
||||
static const struct pll_config_t pll_configuration[] = {
|
||||
/*
|
||||
* PLL frequency setting = 4 (48MHz)
|
||||
* FND div = 0 (PLL / 1 = 48 mhz)
|
||||
* UART div = 1 (PLL / 2 = 24 mhz)
|
||||
* SMB div = 1 (PLL / 2 = 24 mhz)
|
||||
* SSPI div = 1 (PLL / 2 = 24 mhz)
|
||||
* EC div = 6 (FND / 6 = 8 mhz)
|
||||
* JTAG div = 1 (PLL / 2 = 24 mhz)
|
||||
* PWM div = 0 (PLL / 1 = 48 mhz)
|
||||
* USBPD div = 5 (PLL / 6 = 8 mhz)
|
||||
*/
|
||||
{.pll_freq = 4,
|
||||
.div_fnd = 0,
|
||||
.div_uart = 1,
|
||||
.div_smb = 1,
|
||||
.div_sspi = 1,
|
||||
#ifdef CONFIG_SOC_IT8XXX2_EC_BUS_24MHZ
|
||||
.div_ec = 1,
|
||||
#else
|
||||
.div_ec = 6,
|
||||
#endif
|
||||
.div_jtag = 1,
|
||||
.div_pwm = 0,
|
||||
.div_usbpd = 5}
|
||||
};
|
||||
|
||||
void __soc_ram_code chip_run_pll_sequence(const struct pll_config_t *pll)
|
||||
{
|
||||
/* Enable HW timer to wakeup chip from the sleep mode */
|
||||
timer_5ms_one_shot();
|
||||
/*
|
||||
* Configure PLL clock dividers.
|
||||
* Writing data to these registers doesn't change the
|
||||
* PLL frequency immediately until the status is changed
|
||||
* into wakeup from the sleep mode.
|
||||
* The following code is intended to make the system
|
||||
* enter sleep mode, and wait HW timer to wakeup chip to
|
||||
* complete PLL update.
|
||||
*/
|
||||
IT8XXX2_ECPM_PLLFREQR = pll->pll_freq;
|
||||
/* Pre-set FND clock frequency = PLL / 3 */
|
||||
IT8XXX2_ECPM_SCDCR0 = (2 << 4);
|
||||
/* JTAG and EC */
|
||||
IT8XXX2_ECPM_SCDCR3 = (pll->div_jtag << 4) | pll->div_ec;
|
||||
/* Chip sleep after wait for interrupt (wfi) instruction */
|
||||
chip_pll_ctrl(CHIP_PLL_SLEEP);
|
||||
/* Chip sleep and wait timer wake it up */
|
||||
__asm__ volatile ("wfi");
|
||||
/* New FND clock frequency */
|
||||
IT8XXX2_ECPM_SCDCR0 = pll->div_fnd << 4;
|
||||
/* Chip doze after wfi instruction */
|
||||
chip_pll_ctrl(CHIP_PLL_DOZE);
|
||||
/* UART */
|
||||
IT8XXX2_ECPM_SCDCR1 = pll->div_uart;
|
||||
/* SSPI and SMB */
|
||||
IT8XXX2_ECPM_SCDCR2 = (pll->div_sspi << 4) | pll->div_smb;
|
||||
/* USBPD and PWM */
|
||||
IT8XXX2_ECPM_SCDCR4 = (pll->div_usbpd << 4) | pll->div_pwm;
|
||||
}
|
||||
|
||||
static void chip_configure_pll(const struct pll_config_t *pll)
|
||||
{
|
||||
/* Re-configure PLL clock or not. */
|
||||
if (((IT8XXX2_ECPM_PLLFREQR & 0xf) != pll->pll_freq) ||
|
||||
((IT8XXX2_ECPM_SCDCR0 & 0xf0) != (pll->div_fnd << 4)) ||
|
||||
((IT8XXX2_ECPM_SCDCR3 & 0xf) != pll->div_ec)) {
|
||||
#ifdef CONFIG_ESPI
|
||||
/*
|
||||
* We have to disable eSPI pad before changing
|
||||
* PLL sequence or sequence will fail if CS# pin is low.
|
||||
*/
|
||||
espi_it8xxx2_enable_pad_ctrl(ESPI_IT8XXX2_SOC_DEV, false);
|
||||
#endif
|
||||
/* Run change PLL sequence */
|
||||
chip_run_pll_sequence(pll);
|
||||
#ifdef CONFIG_ESPI
|
||||
/* Enable eSPI pad after changing PLL sequence */
|
||||
espi_it8xxx2_enable_pad_ctrl(ESPI_IT8XXX2_SOC_DEV, true);
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
||||
static int chip_change_pll(void)
|
||||
{
|
||||
|
||||
if (IS_ENABLED(CONFIG_HAS_ITE_INTC)) {
|
||||
ite_intc_save_and_disable_interrupts();
|
||||
}
|
||||
/* configure PLL/CPU/flash clock */
|
||||
chip_configure_pll(&pll_configuration[0]);
|
||||
if (IS_ENABLED(CONFIG_HAS_ITE_INTC)) {
|
||||
ite_intc_restore_interrupts();
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
SYS_INIT(chip_change_pll, PRE_KERNEL_1, CONFIG_IT8XXX2_PLL_SEQUENCE_PRIORITY);
|
||||
BUILD_ASSERT(CONFIG_FLASH_INIT_PRIORITY < CONFIG_IT8XXX2_PLL_SEQUENCE_PRIORITY,
|
||||
"CONFIG_FLASH_INIT_PRIORITY must be less than CONFIG_IT8XXX2_PLL_SEQUENCE_PRIORITY");
|
||||
#endif /* CONFIG_SOC_IT8XXX2_PLL_FLASH_48M */
|
||||
|
||||
#ifdef CONFIG_SOC_IT8XXX2_CPU_IDLE_GATING
|
||||
/* Preventing CPU going into idle mode during command queue. */
|
||||
static atomic_t cpu_idle_disabled;
|
||||
|
||||
void chip_permit_idle(void)
|
||||
{
|
||||
atomic_dec(&cpu_idle_disabled);
|
||||
}
|
||||
|
||||
void chip_block_idle(void)
|
||||
{
|
||||
atomic_inc(&cpu_idle_disabled);
|
||||
}
|
||||
|
||||
bool cpu_idle_not_allowed(void)
|
||||
{
|
||||
return !!(atomic_get(&cpu_idle_disabled));
|
||||
}
|
||||
#endif
|
||||
|
||||
/* The routine must be called with interrupts locked */
|
||||
void riscv_idle(enum chip_pll_mode mode, unsigned int key)
|
||||
{
|
||||
/*
|
||||
* The routine is called with interrupts locked (in kernel/idle()).
|
||||
* But on kernel/context test_kernel_cpu_idle test, the routine will be
|
||||
* called without interrupts locked. Hence we disable M-mode external
|
||||
* interrupt here to protect the below content.
|
||||
*/
|
||||
csr_clear(mie, MIP_MEIP);
|
||||
sys_trace_idle();
|
||||
#ifdef CONFIG_ESPI
|
||||
/*
|
||||
* H2RAM feature requires RAM clock to be active. Since the below doze
|
||||
* mode will disable CPU and RAM clocks, enable eSPI transaction
|
||||
* interrupt to restore clocks. With this interrupt, EC will not defer
|
||||
* eSPI bus while transaction is accepted.
|
||||
*/
|
||||
espi_it8xxx2_enable_trans_irq(ESPI_IT8XXX2_SOC_DEV, true);
|
||||
#endif
|
||||
/* Chip doze after wfi instruction */
|
||||
chip_pll_ctrl(mode);
|
||||
|
||||
do {
|
||||
/* Wait for interrupt */
|
||||
__asm__ volatile ("wfi");
|
||||
/*
|
||||
* Sometimes wfi instruction may fail due to CPU's MTIP@mip
|
||||
* register is non-zero.
|
||||
* If the ite_intc_no_irq() is true at this point,
|
||||
* it means that EC waked-up by the above issue not an
|
||||
* interrupt. Hence we loop running wfi instruction here until
|
||||
* wfi success.
|
||||
*/
|
||||
} while (ite_intc_no_irq());
|
||||
|
||||
#ifdef CONFIG_ESPI
|
||||
/* CPU has been woken up, the interrupt is no longer needed */
|
||||
espi_it8xxx2_enable_trans_irq(ESPI_IT8XXX2_SOC_DEV, false);
|
||||
#endif
|
||||
/*
|
||||
* Enable M-mode external interrupt
|
||||
* An interrupt can not be fired yet until we enable global interrupt
|
||||
*/
|
||||
csr_set(mie, MIP_MEIP);
|
||||
/* Restore global interrupt lockout state */
|
||||
irq_unlock(key);
|
||||
}
|
||||
|
||||
void arch_cpu_idle(void)
|
||||
{
|
||||
#ifdef CONFIG_SOC_IT8XXX2_CPU_IDLE_GATING
|
||||
/*
|
||||
* The EC processor(CPU) cannot be in the k_cpu_idle() during
|
||||
* the transactions with the CQ mode(DMA mode). Otherwise,
|
||||
* the EC processor would be clock gated.
|
||||
*/
|
||||
if (cpu_idle_not_allowed()) {
|
||||
/* Restore global interrupt lockout state */
|
||||
irq_unlock(MSTATUS_IEN);
|
||||
} else
|
||||
#endif
|
||||
{
|
||||
riscv_idle(CHIP_PLL_DOZE, MSTATUS_IEN);
|
||||
}
|
||||
}
|
||||
|
||||
void arch_cpu_atomic_idle(unsigned int key)
|
||||
{
|
||||
riscv_idle(CHIP_PLL_DOZE, key);
|
||||
}
|
||||
|
||||
static int ite_it8xxx2_init(void)
|
||||
{
|
||||
struct gpio_it8xxx2_regs *const gpio_regs = GPIO_IT8XXX2_REG_BASE;
|
||||
struct gctrl_it8xxx2_regs *const gctrl_regs = GCTRL_IT8XXX2_REGS_BASE;
|
||||
|
||||
#if DT_NODE_HAS_STATUS(DT_NODELABEL(usb0), disabled)
|
||||
struct usb_it82xx2_regs *const usb_regs = USB_IT82XX2_REGS_BASE;
|
||||
|
||||
usb_regs->port0_misc_control &= ~PULL_DOWN_EN;
|
||||
usb_regs->port1_misc_control &= ~PULL_DOWN_EN;
|
||||
#endif
|
||||
|
||||
/*
|
||||
* bit7: wake up CPU if it is in low power mode and
|
||||
* an interrupt is pending.
|
||||
*/
|
||||
gctrl_regs->GCTRL_WMCR |= BIT(7);
|
||||
|
||||
/*
|
||||
* Disable this feature that can detect pre-define hardware
|
||||
* target A through I2C0. This is for debugging use, so it
|
||||
* can be disabled to avoid illegal access.
|
||||
*/
|
||||
#ifdef CONFIG_SOC_IT8XXX2_REG_SET_V1
|
||||
IT8XXX2_SMB_SFFCTL &= ~IT8XXX2_SMB_HSAPE;
|
||||
#elif CONFIG_SOC_IT8XXX2_REG_SET_V2
|
||||
IT8XXX2_SMB_SCLKTS_BRGS &= ~IT8XXX2_SMB_PREDEN;
|
||||
/*
|
||||
* Setting this bit will disable EGAD pin output driving to avoid
|
||||
* leakage when GPIO E1/E2 on it82002 are set to alternate function.
|
||||
*/
|
||||
IT8XXX2_EGPIO_EGCR |= IT8XXX2_EGPIO_EEPODD;
|
||||
#endif
|
||||
|
||||
#if DT_NODE_HAS_STATUS(DT_NODELABEL(uart1), okay)
|
||||
/* UART1 board init */
|
||||
/* bit2: clocks to UART1 modules are not gated. */
|
||||
IT8XXX2_ECPM_CGCTRL3R &= ~BIT(2);
|
||||
IT8XXX2_ECPM_AUTOCG &= ~BIT(6);
|
||||
|
||||
/* bit3: UART1 belongs to the EC side. */
|
||||
gctrl_regs->GCTRL_RSTDMMC |= IT8XXX2_GCTRL_UART1SD;
|
||||
/* reset UART before config it */
|
||||
gctrl_regs->GCTRL_RSTC4 = IT8XXX2_GCTRL_RUART1;
|
||||
|
||||
/* switch UART1 on without hardware flow control */
|
||||
gpio_regs->GPIO_GCR1 |= IT8XXX2_GPIO_U1CTRL_SIN0_SOUT0_EN;
|
||||
|
||||
#endif /* DT_NODE_HAS_STATUS(DT_NODELABEL(uart1), okay) */
|
||||
|
||||
#if DT_NODE_HAS_STATUS(DT_NODELABEL(uart2), okay)
|
||||
/* UART2 board init */
|
||||
/* setting voltage 3.3v */
|
||||
gpio_regs->GPIO_GCR21 &= ~(IT8XXX2_GPIO_GPH1VS | IT8XXX2_GPIO_GPH2VS);
|
||||
/* bit2: clocks to UART2 modules are not gated. */
|
||||
IT8XXX2_ECPM_CGCTRL3R &= ~BIT(2);
|
||||
IT8XXX2_ECPM_AUTOCG &= ~BIT(5);
|
||||
|
||||
/* bit3: UART2 belongs to the EC side. */
|
||||
gctrl_regs->GCTRL_RSTDMMC |= IT8XXX2_GCTRL_UART2SD;
|
||||
/* reset UART before config it */
|
||||
gctrl_regs->GCTRL_RSTC4 = IT8XXX2_GCTRL_RUART2;
|
||||
|
||||
/* switch UART2 on without hardware flow control */
|
||||
gpio_regs->GPIO_GCR1 |= IT8XXX2_GPIO_U2CTRL_SIN1_SOUT1_EN;
|
||||
|
||||
#endif /* DT_NODE_HAS_STATUS(DT_NODELABEL(uart2), okay) */
|
||||
|
||||
#if (SOC_USBPD_ITE_PHY_PORT_COUNT > 0)
|
||||
int port;
|
||||
|
||||
/*
|
||||
* To prevent cc pins leakage, we disable board not active ITE
|
||||
* TCPC port cc modules, then cc pins can be used as gpio if needed.
|
||||
*/
|
||||
for (port = SOC_USBPD_ITE_ACTIVE_PORT_COUNT;
|
||||
port < SOC_USBPD_ITE_PHY_PORT_COUNT; port++) {
|
||||
struct usbpd_it8xxx2_regs *base;
|
||||
|
||||
if (port == 0) {
|
||||
base = (struct usbpd_it8xxx2_regs *)DT_REG_ADDR(DT_NODELABEL(usbpd0));
|
||||
} else if (port == 1) {
|
||||
base = (struct usbpd_it8xxx2_regs *)DT_REG_ADDR(DT_NODELABEL(usbpd1));
|
||||
} else {
|
||||
/* Currently all ITE embedded pd chip support max two ports */
|
||||
break;
|
||||
}
|
||||
|
||||
/* Power down all CC, and disable CC voltage detector */
|
||||
base->CCGCR |= (IT8XXX2_USBPD_DISABLE_CC |
|
||||
IT8XXX2_USBPD_DISABLE_CC_VOL_DETECTOR);
|
||||
/*
|
||||
* Disconnect CC analog module (ex.UP/RD/DET/TX/RX), and
|
||||
* disconnect CC 5.1K to GND
|
||||
*/
|
||||
base->CCCSR |= (IT8XXX2_USBPD_CC2_DISCONNECT |
|
||||
IT8XXX2_USBPD_CC2_DISCONNECT_5_1K_TO_GND |
|
||||
IT8XXX2_USBPD_CC1_DISCONNECT |
|
||||
IT8XXX2_USBPD_CC1_DISCONNECT_5_1K_TO_GND);
|
||||
/* Disconnect CC 5V tolerant */
|
||||
base->CCPSR |= (IT8XXX2_USBPD_DISCONNECT_POWER_CC2 |
|
||||
IT8XXX2_USBPD_DISCONNECT_POWER_CC1);
|
||||
/* Dis-connect 5.1K dead battery resistor to CC */
|
||||
base->CCPSR |= (IT8XXX2_USBPD_DISCONNECT_5_1K_CC2_DB |
|
||||
IT8XXX2_USBPD_DISCONNECT_5_1K_CC1_DB);
|
||||
}
|
||||
#endif /* (SOC_USBPD_ITE_PHY_PORT_COUNT > 0) */
|
||||
|
||||
return 0;
|
||||
}
|
||||
SYS_INIT(ite_it8xxx2_init, PRE_KERNEL_1, CONFIG_KERNEL_INIT_PRIORITY_DEFAULT);
|
12
soc/ite/ec/it8xxx2/soc.h
Normal file
12
soc/ite/ec/it8xxx2/soc.h
Normal file
|
@ -0,0 +1,12 @@
|
|||
#ifndef __RISCV_ITE_SOC_H_
|
||||
#define __RISCV_ITE_SOC_H_
|
||||
/*
|
||||
* Copyright (c) 2020 ITE Corporation. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
*/
|
||||
#include <soc_common.h>
|
||||
|
||||
|
||||
#endif /* __RISCV_ITE_SOC_H_ */
|
12
soc/ite/ec/soc.yml
Normal file
12
soc/ite/ec/soc.yml
Normal file
|
@ -0,0 +1,12 @@
|
|||
family:
|
||||
- name: ite_ec
|
||||
series:
|
||||
- name: it8xxxx
|
||||
socs:
|
||||
- name: it81202bx
|
||||
- name: it81202cx
|
||||
- name: it81302bx
|
||||
- name: it81302cx
|
||||
- name: it82002aw
|
||||
- name: it82202ax
|
||||
- name: it82302ax
|
Loading…
Add table
Add a link
Reference in a new issue