|  | /* | 
|  | * Copyright (c) 2017 Linaro Limited | 
|  | * | 
|  | * SPDX-License-Identifier: Apache-2.0 | 
|  | */ | 
|  |  | 
|  | /dts-v1/; | 
|  | #include <st/l4/stm32l496Xg.dtsi> | 
|  | #include <st/l4/stm32l496a(e-g)ix-pinctrl.dtsi> | 
|  | #include "arduino_r3_connector.dtsi" | 
|  | #include <zephyr/dt-bindings/input/input-event-codes.h> | 
|  |  | 
|  | / { | 
|  | model = "STMicroelectronics STM32L496G-DISCO board"; | 
|  | compatible = "st,stm32l496g-disco"; | 
|  |  | 
|  | chosen { | 
|  | zephyr,console = &usart2; | 
|  | zephyr,shell-uart = &usart2; | 
|  | zephyr,sram = &sram0; | 
|  | zephyr,flash = &flash0; | 
|  | zephyr,flash-controller = &mx25r6435; | 
|  | }; | 
|  |  | 
|  | leds { | 
|  | compatible = "gpio-leds"; | 
|  | green_led_2: led_2 { | 
|  | gpios = <&gpiob 13 GPIO_ACTIVE_HIGH>; | 
|  | label = "User LD2"; | 
|  | }; | 
|  | }; | 
|  |  | 
|  | gpio_keys { | 
|  | compatible = "gpio-keys"; | 
|  | joy_sel: joystick_select { | 
|  | label = "joystick select"; | 
|  | gpios = <&gpioc 13 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>; | 
|  | zephyr,code = <INPUT_KEY_ENTER>; | 
|  | }; | 
|  | joy_down: joystick_down { | 
|  | label = "joystick down"; | 
|  | gpios = <&gpioi 10 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>; | 
|  | zephyr,code = <INPUT_KEY_DOWN>; | 
|  | }; | 
|  | joy_up: joystick_up { | 
|  | label = "joystick up"; | 
|  | gpios = <&gpioi 8 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>; | 
|  | zephyr,code = <INPUT_KEY_UP>; | 
|  | }; | 
|  | joy_left: joystick_left { | 
|  | label = "joystick left"; | 
|  | gpios = <&gpioi 9 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>; | 
|  | zephyr,code = <INPUT_KEY_LEFT>; | 
|  | }; | 
|  | joy_right: joystick_right { | 
|  | label = "joystick right"; | 
|  | gpios = <&gpiof 11 (GPIO_ACTIVE_HIGH | GPIO_PULL_DOWN)>; | 
|  | zephyr,code = <INPUT_KEY_RIGHT>; | 
|  | }; | 
|  | }; | 
|  |  | 
|  | aliases { | 
|  | led0 = &green_led_2; | 
|  | sw0 = &joy_sel; | 
|  | sw1 = &joy_down; | 
|  | sw2 = &joy_right; | 
|  | sw3 = &joy_up; | 
|  | sw4 = &joy_left; | 
|  | volt-sensor0 = &vref; | 
|  | volt-sensor1 = &vbat; | 
|  | spi-flash0 = &mx25r6435; | 
|  | }; | 
|  |  | 
|  | }; | 
|  |  | 
|  | &clk_lsi { | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &clk_hsi48 { | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &clk_hsi { | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &pll { | 
|  | div-m = <1>; | 
|  | mul-n = <20>; | 
|  | div-p = <7>; | 
|  | div-q = <2>; | 
|  | div-r = <4>; | 
|  | clocks = <&clk_hsi>; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &rcc { | 
|  | clocks = <&pll>; | 
|  | clock-frequency = <DT_FREQ_M(80)>; | 
|  | ahb-prescaler = <1>; | 
|  | apb1-prescaler = <1>; | 
|  | apb2-prescaler = <1>; | 
|  | }; | 
|  |  | 
|  | &usart1 { | 
|  | pinctrl-0 = <&usart1_tx_pb6 &usart1_rx_pg10>; | 
|  | pinctrl-names = "default"; | 
|  | current-speed = <115200>; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &usart2 { | 
|  | pinctrl-0 = <&usart2_tx_pa2 &usart2_rx_pd6>; | 
|  | pinctrl-names = "default"; | 
|  | current-speed = <115200>; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &lpuart1 { | 
|  | pinctrl-0 = <&lpuart1_tx_pg7 &lpuart1_rx_pg8>; | 
|  | pinctrl-names = "default"; | 
|  | current-speed = <115200>; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &timers2 { | 
|  | status = "okay"; | 
|  |  | 
|  | pwm2: pwm { | 
|  | status = "okay"; | 
|  | pinctrl-0 = <&tim2_ch1_pa0>; | 
|  | pinctrl-names = "default"; | 
|  | }; | 
|  | }; | 
|  |  | 
|  | &i2c1 { | 
|  | pinctrl-0 = <&i2c1_scl_pb8 &i2c1_sda_pb7>; | 
|  | pinctrl-names = "default"; | 
|  | status = "okay"; | 
|  | clock-frequency = <I2C_BITRATE_FAST>; | 
|  | }; | 
|  |  | 
|  | &spi1 { | 
|  | pinctrl-0 = <&spi1_sck_pa5 &spi1_miso_pb4 &spi1_mosi_pb5>; | 
|  | pinctrl-names = "default"; | 
|  | cs-gpios = <&gpioa 15 (GPIO_ACTIVE_LOW | GPIO_PULL_UP)>; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &rtc { | 
|  | clocks = <&rcc STM32_CLOCK_BUS_APB1 0x10000000>, | 
|  | <&rcc STM32_SRC_LSI RTC_SEL(2)>; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &sdmmc1 { | 
|  | pinctrl-0 = <&sdmmc1_d0_pc8 &sdmmc1_d1_pc9 | 
|  | &sdmmc1_d2_pc10 &sdmmc1_d3_pc11 | 
|  | &sdmmc1_ck_pc12 &sdmmc1_cmd_pd2>; | 
|  | pinctrl-names = "default"; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &adc1 { | 
|  | pinctrl-0 = < &adc1_in2_pc1>; | 
|  | pinctrl-names = "default"; | 
|  | st,adc-clock-source = <SYNC>; | 
|  | st,adc-prescaler = <4>; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | zephyr_udc0: &usbotg_fs { | 
|  | pinctrl-0 = <&usb_otg_fs_dm_pa11 &usb_otg_fs_dp_pa12 | 
|  | &usb_otg_fs_id_pa10>; | 
|  | pinctrl-names = "default"; | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &vref { | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &vbat { | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &dma2 { | 
|  | status = "okay"; | 
|  | }; | 
|  |  | 
|  | &quadspi { | 
|  | pinctrl-0 = <&quadspi_bk1_io0_pb1 &quadspi_bk1_io1_pb0 | 
|  | &quadspi_bk1_io2_pa7 &quadspi_bk1_io3_pa6 | 
|  | &quadspi_bk1_ncs_pb11 &quadspi_clk_pa3>; | 
|  | pinctrl-names = "default"; | 
|  |  | 
|  | dmas = <&dma2 7 3 0x480>; /* channel 7 request 3 on DMA2 */ | 
|  | dma-names = "tx_rx"; | 
|  |  | 
|  | flash-id = <1>; | 
|  | status = "okay"; | 
|  |  | 
|  | mx25r6435: qspi-nor-flash@0 { | 
|  | compatible = "st,stm32-qspi-nor"; | 
|  | reg = <0>; | 
|  | qspi-max-frequency = <8000000>; | 
|  | size = <DT_SIZE_M(64)>; /* 8 MBytes */ | 
|  | status = "okay"; | 
|  | spi-bus-width = <4>; | 
|  | writeoc = "PP_1_4_4"; | 
|  | }; | 
|  | }; |