Anforderungen  |   Konzepte  |   Entwurf  |   Entwicklung  |   Qualitätssicherung  |   Lebenszyklus  |   Steuerung
 
 
 
 


Quelle  meson-sm1-odroid.dtsi   Sprache: unbekannt

 
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
/*
 * Copyright (c) 2020 Dongjin Kim <tobetter@gmail.com>
 */

#include "meson-sm1.dtsi"
#include <dt-bindings/gpio/meson-g12a-gpio.h>
#include <dt-bindings/leds/common.h>
#include <dt-bindings/sound/meson-g12a-tohdmitx.h>

/ {
 aliases {
  serial0 = &uart_AO;
  ethernet0 = ðmac;
 };

 chosen {
  stdout-path = "serial0:115200n8";
 };

 memory@0 {
  device_type = "memory";
  reg = <0x0 0x0 0x0 0x40000000>;
 };

 emmc_pwrseq: emmc-pwrseq {
  compatible = "mmc-pwrseq-emmc";
  reset-gpios = <&gpio BOOT_12 GPIO_ACTIVE_LOW>;
 };

 tflash_vdd: regulator-tflash-vdd {
  compatible = "regulator-fixed";

  regulator-name = "TFLASH_VDD";
  regulator-min-microvolt = <3300000>;
  regulator-max-microvolt = <3300000>;

  gpio = <&gpio_ao GPIOAO_3 GPIO_OPEN_DRAIN>;
  enable-active-high;
  regulator-always-on;
 };

 tf_io: gpio-regulator-tf-io {
  compatible = "regulator-gpio";

  regulator-name = "TF_IO";
  regulator-min-microvolt = <1800000>;
  regulator-max-microvolt = <3300000>;
  vin-supply = <&vcc_5v>;

  enable-gpios = <&gpio_ao GPIOE_2 GPIO_OPEN_DRAIN>;
  enable-active-high;
  regulator-always-on;

  gpios = <&gpio_ao GPIOAO_6 GPIO_OPEN_SOURCE>;
  gpios-states = <0>;

  states = <3300000 0>,
    <1800000 1>;
 };

 flash_1v8: regulator-flash-1v8 {
  compatible = "regulator-fixed";
  regulator-name = "FLASH_1V8";
  regulator-min-microvolt = <1800000>;
  regulator-max-microvolt = <1800000>;
  vin-supply = <&vcc_3v3>;
  regulator-always-on;
 };

 main_12v: regulator-main-12v {
  compatible = "regulator-fixed";
  regulator-name = "12V";
  regulator-min-microvolt = <12000000>;
  regulator-max-microvolt = <12000000>;
  regulator-always-on;
 };

 vcc_5v: regulator-vcc-5v {
  compatible = "regulator-fixed";
  regulator-name = "5V";
  regulator-min-microvolt = <5000000>;
  regulator-max-microvolt = <5000000>;
  regulator-always-on;
  vin-supply = <&main_12v>;
  gpio = <&gpio GPIOH_8 GPIO_OPEN_DRAIN>;
  enable-active-high;
 };

 vcc_1v8: regulator-vcc-1v8 {
  compatible = "regulator-fixed";
  regulator-name = "VCC_1V8";
  regulator-min-microvolt = <1800000>;
  regulator-max-microvolt = <1800000>;
  vin-supply = <&vcc_3v3>;
  regulator-always-on;
 };

 vcc_3v3: regulator-vcc-3v3 {
  compatible = "regulator-fixed";
  regulator-name = "VCC_3V3";
  regulator-min-microvolt = <3300000>;
  regulator-max-microvolt = <3300000>;
  vin-supply = <&vddao_3v3>;
  regulator-always-on;
  /* FIXME: actually controlled by VDDCPU_B_EN */
 };

 vddcpu: regulator-vddcpu {
  /*
   * MP8756GD Regulator.
   */
  compatible = "pwm-regulator";

  regulator-name = "VDDCPU";
  regulator-min-microvolt = <721000>;
  regulator-max-microvolt = <1022000>;

  pwm-supply = <&main_12v>;

  pwms = <&pwm_AO_cd 1 1250 0>;
  pwm-dutycycle-range = <100 0>;

  regulator-boot-on;
  regulator-always-on;
 };

 usb_pwr_en: regulator-usb-pwr-en {
  compatible = "regulator-fixed";
  regulator-name = "USB_PWR_EN";
  regulator-min-microvolt = <5000000>;
  regulator-max-microvolt = <5000000>;
  vin-supply = <&vcc_5v>;

  /* Connected to the microUSB port power enable */
  gpio = <&gpio_ao GPIOAO_2 GPIO_ACTIVE_HIGH>;
  enable-active-high;
 };

 vddao_1v8: regulator-vddao-1v8 {
  compatible = "regulator-fixed";
  regulator-name = "VDDAO_1V8";
  regulator-min-microvolt = <1800000>;
  regulator-max-microvolt = <1800000>;
  vin-supply = <&vddao_3v3>;
  regulator-always-on;
 };

 vddao_3v3: regulator-vddao-3v3 {
  compatible = "regulator-fixed";
  regulator-name = "VDDAO_3V3";
  regulator-min-microvolt = <3300000>;
  regulator-max-microvolt = <3300000>;
  vin-supply = <&main_12v>;
  regulator-always-on;
 };

 hdmi-connector {
  compatible = "hdmi-connector";
  type = "a";

  port {
   hdmi_connector_in: endpoint {
    remote-endpoint = <&hdmi_tx_tmds_out>;
   };
  };
 };

 sound {
  compatible = "amlogic,axg-sound-card";
  audio-aux-devs = <&tdmout_b>;
  audio-routing = "TDMOUT_B IN 0", "FRDDR_A OUT 1",
    "TDMOUT_B IN 1", "FRDDR_B OUT 1",
    "TDMOUT_B IN 2", "FRDDR_C OUT 1",
    "TDM_B Playback", "TDMOUT_B OUT";

  clocks = <&clkc CLKID_MPLL2>,
    <&clkc CLKID_MPLL0>,
    <&clkc CLKID_MPLL1>;

  assigned-clocks = <&clkc CLKID_MPLL2>,
      <&clkc CLKID_MPLL0>,
      <&clkc CLKID_MPLL1>;
  assigned-clock-parents = <0>, <0>, <0>;
  assigned-clock-rates = <294912000>,
           <270950400>,
           <393216000>;

  dai-link-0 {
   sound-dai = <&frddr_a>;
  };

  dai-link-1 {
   sound-dai = <&frddr_b>;
  };

  dai-link-2 {
   sound-dai = <&frddr_c>;
  };

  /* 8ch hdmi interface */
  dai-link-3 {
   sound-dai = <&tdmif_b>;
   dai-format = "i2s";
   dai-tdm-slot-tx-mask-0 = <1 1>;
   dai-tdm-slot-tx-mask-1 = <1 1>;
   dai-tdm-slot-tx-mask-2 = <1 1>;
   dai-tdm-slot-tx-mask-3 = <1 1>;
   mclk-fs = <256>;

   codec {
    sound-dai = <&tohdmitx TOHDMITX_I2S_IN_B>;
   };
  };

  /* hdmi glue */
  dai-link-4 {
   sound-dai = <&tohdmitx TOHDMITX_I2S_OUT>;

   codec {
    sound-dai = <&hdmi_tx>;
   };
  };
 };
};

&arb {
 status = "okay";
};

&cec_AO {
 pinctrl-0 = <&cec_ao_a_h_pins>;
 pinctrl-names = "default";
 status = "disabled";
 hdmi-phandle = <&hdmi_tx>;
};

&cecb_AO {
 pinctrl-0 = <&cec_ao_b_h_pins>;
 pinctrl-names = "default";
 status = "okay";
 hdmi-phandle = <&hdmi_tx>;
};

&clkc_audio {
 status = "okay";
};

&cpu0 {
 cpu-supply = <&vddcpu>;
 operating-points-v2 = <&cpu_opp_table>;
 clocks = <&clkc CLKID_CPU_CLK>;
};

&cpu1 {
 cpu-supply = <&vddcpu>;
 operating-points-v2 = <&cpu_opp_table>;
 clocks = <&clkc CLKID_CPU1_CLK>;
};

&cpu2 {
 cpu-supply = <&vddcpu>;
 operating-points-v2 = <&cpu_opp_table>;
 clocks = <&clkc CLKID_CPU2_CLK>;
};

&cpu3 {
 cpu-supply = <&vddcpu>;
 operating-points-v2 = <&cpu_opp_table>;
 clocks = <&clkc CLKID_CPU3_CLK>;
};

&ext_mdio {
 external_phy: ethernet-phy@0 {
  /* Realtek RTL8211F (0x001cc916) */
  reg = <0>;
  max-speed = <1000>;

  reset-assert-us = <10000>;
  reset-deassert-us = <80000>;
  reset-gpios = <&gpio GPIOZ_15 (GPIO_ACTIVE_LOW | GPIO_OPEN_DRAIN)>;

  interrupt-parent = <&gpio_intc>;
  /* MAC_INTR on GPIOZ_14 */
  interrupts = <IRQID_GPIOZ_14 IRQ_TYPE_LEVEL_LOW>;
 };
};

ðmac {
 pinctrl-0 = <ð_pins>, <ð_rgmii_pins>;
 pinctrl-names = "default";
 status = "okay";
 phy-mode = "rgmii";
 phy-handle = <&external_phy>;
 amlogic,tx-delay-ns = <2>;
};

&frddr_a {
 status = "okay";
};

&frddr_b {
 status = "okay";
};

&frddr_c {
 status = "okay";
};

&gpio {
 gpio-line-names =
  /* GPIOZ */
  "", "", "", "", "", "", "", "",
  "", "", "", "", "", "", "", "",
  /* GPIOH */
  "", "", "", "", "",
  "PIN_36", /* GPIOH_5 */
  "PIN_26", /* GPIOH_6 */
  "PIN_32", /* GPIOH_7 */
  "",
  /* BOOT */
  "", "", "", "", "", "", "", "",
  "", "", "", "", "", "", "", "",
  /* GPIOC */
  "", "", "", "", "", "", "", "",
  /* GPIOA */
  "", "", "", "", "", "", "", "",
  "", "", "", "", "", "",
  "PIN_27", /* GPIOA_14 */
  "PIN_28", /* GPIOA_15 */
  /* GPIOX */
  "PIN_16", /* GPIOX_0 */
  "PIN_18", /* GPIOX_1 */
  "PIN_22", /* GPIOX_2 */
  "PIN_11", /* GPIOX_3 */
  "PIN_13", /* GPIOX_4 */
  "PIN_7",  /* GPIOX_5 */
  "PIN_33", /* GPIOX_6 */
  "PIN_15", /* GPIOX_7 */
  "PIN_19", /* GPIOX_8 */
  "PIN_21", /* GPIOX_9 */
  "PIN_24", /* GPIOX_10 */
  "PIN_23", /* GPIOX_11 */
  "PIN_8",  /* GPIOX_12 */
  "PIN_10", /* GPIOX_13 */
  "PIN_29", /* GPIOX_14 */
  "PIN_31", /* GPIOX_15 */
  "PIN_12", /* GPIOX_16 */
  "PIN_3",  /* GPIOX_17 */
  "PIN_5",  /* GPIOX_18 */
  "PIN_35"; /* GPIOX_19 */
};

&gpio_ao {
 gpio-line-names =
  /* GPIOAO */
  "", "", "", "",
  "PIN_47", /* GPIOAO_4 */
  "", "",
  "PIN_45", /* GPIOAO_7 */
  "PIN_46", /* GPIOAO_8 */
  "PIN_44", /* GPIOAO_9 */
  "PIN_42", /* GPIOAO_10 */
  "",
  /* GPIOE */
  "", "", "";
};

&hdmi_tx {
 status = "okay";
 pinctrl-0 = <&hdmitx_hpd_pins>, <&hdmitx_ddc_pins>;
 pinctrl-names = "default";
 hdmi-supply = <&vcc_5v>;
};

&hdmi_tx_tmds_port {
 hdmi_tx_tmds_out: endpoint {
  remote-endpoint = <&hdmi_connector_in>;
 };
};

&ir {
 status = "okay";
 pinctrl-0 = <&remote_input_ao_pins>;
 pinctrl-names = "default";
};

&pwm_AO_cd {
 pinctrl-0 = <&pwm_ao_d_e_pins>;
 pinctrl-names = "default";
 status = "okay";
};

&saradc {
 status = "okay";
};

/* SD card */
&sd_emmc_b {
 status = "okay";
 pinctrl-0 = <&sdcard_c_pins>;
 pinctrl-1 = <&sdcard_clk_gate_c_pins>;
 pinctrl-names = "default", "clk-gate";

 bus-width = <4>;
 cap-sd-highspeed;
 max-frequency = <200000000>;
 sd-uhs-sdr12;
 sd-uhs-sdr25;
 sd-uhs-sdr50;
 sd-uhs-sdr104;
 disable-wp;

 cd-gpios = <&gpio GPIOC_6 GPIO_ACTIVE_LOW>;
 vmmc-supply = <&tflash_vdd>;
 vqmmc-supply = <&tf_io>;
};

/* eMMC */
&sd_emmc_c {
 status = "okay";
 pinctrl-0 = <&emmc_ctrl_pins>, <&emmc_data_8b_pins>, <&emmc_ds_pins>;
 pinctrl-1 = <&emmc_clk_gate_pins>;
 pinctrl-names = "default", "clk-gate";

 bus-width = <8>;
 cap-mmc-highspeed;
 mmc-ddr-1_8v;
 mmc-hs200-1_8v;
 max-frequency = <200000000>;
 disable-wp;

 mmc-pwrseq = <&emmc_pwrseq>;
 vmmc-supply = <&vcc_3v3>;
 vqmmc-supply = <&flash_1v8>;
};

&tdmif_b {
 status = "okay";
};

&tdmout_b {
 status = "okay";
};

&tohdmitx {
 status = "okay";
};

&uart_AO {
 status = "okay";
 pinctrl-0 = <&uart_ao_a_pins>;
 pinctrl-names = "default";
};

&usb {
 status = "okay";
 vbus-supply = <&usb_pwr_en>;
};

&usb2_phy0 {
 phy-supply = <&vcc_5v>;
};


[ Dauer der Verarbeitung: 0.3 Sekunden  (vorverarbeitet)  ]

                                                                                                                                                                                                                                                                                                                                                                                                     


Neuigkeiten

     Aktuelles
     Motto des Tages

Software

     Produkte
     Quellcodebibliothek

Aktivitäten

     Artikel über Sicherheit
     Anleitung zur Aktivierung von SSL

Muße

     Gedichte
     Musik
     Bilder

Jenseits des Üblichen ....
    

Besucherstatistik

Besucherstatistik

Monitoring

Montastic status badge