162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0+
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Device Tree file for the Kontron SMARC-sAL28 board on a SMARC Eval 2.0
462306a36Sopenharmony_ci * carrier (ADS2).
562306a36Sopenharmony_ci *
662306a36Sopenharmony_ci * Copyright (C) 2019 Michael Walle <michael@walle.cc>
762306a36Sopenharmony_ci *
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci/dts-v1/;
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ci#include <dt-bindings/clock/fsl,qoriq-clockgen.h>
1362306a36Sopenharmony_ci#include "fsl-ls1028a-kontron-sl28.dts"
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci/ {
1662306a36Sopenharmony_ci	model = "Kontron SMARC-sAL28 (Single PHY) on SMARC Eval 2.0 carrier";
1762306a36Sopenharmony_ci	compatible = "kontron,sl28-var3-ads2", "kontron,sl28-var3",
1862306a36Sopenharmony_ci		     "kontron,sl28", "fsl,ls1028a";
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci	pwm-fan {
2162306a36Sopenharmony_ci		compatible = "pwm-fan";
2262306a36Sopenharmony_ci		cooling-min-state = <0>;
2362306a36Sopenharmony_ci		cooling-max-state = <3>;
2462306a36Sopenharmony_ci		#cooling-cells = <2>;
2562306a36Sopenharmony_ci		pwms = <&sl28cpld_pwm0 0 4000000>;
2662306a36Sopenharmony_ci		cooling-levels = <1 128 192 255>;
2762306a36Sopenharmony_ci	};
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci	sound {
3062306a36Sopenharmony_ci		#address-cells = <1>;
3162306a36Sopenharmony_ci		#size-cells = <0>;
3262306a36Sopenharmony_ci		compatible = "simple-audio-card";
3362306a36Sopenharmony_ci		simple-audio-card,widgets =
3462306a36Sopenharmony_ci			"Headphone", "Headphone Jack",
3562306a36Sopenharmony_ci			"Line", "Line Out Jack",
3662306a36Sopenharmony_ci			"Microphone", "Microphone Jack",
3762306a36Sopenharmony_ci			"Line", "Line In Jack";
3862306a36Sopenharmony_ci		simple-audio-card,routing =
3962306a36Sopenharmony_ci			"Line Out Jack", "LINEOUTR",
4062306a36Sopenharmony_ci			"Line Out Jack", "LINEOUTL",
4162306a36Sopenharmony_ci			"Headphone Jack", "HPOUTR",
4262306a36Sopenharmony_ci			"Headphone Jack", "HPOUTL",
4362306a36Sopenharmony_ci			"IN1L", "Line In Jack",
4462306a36Sopenharmony_ci			"IN1R", "Line In Jack",
4562306a36Sopenharmony_ci			"Microphone Jack", "MICBIAS",
4662306a36Sopenharmony_ci			"IN2L", "Microphone Jack",
4762306a36Sopenharmony_ci			"IN2R", "Microphone Jack";
4862306a36Sopenharmony_ci		simple-audio-card,mclk-fs = <256>;
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci		simple-audio-card,dai-link@0 {
5162306a36Sopenharmony_ci			reg = <0>;
5262306a36Sopenharmony_ci			bitclock-master = <&dailink0_master>;
5362306a36Sopenharmony_ci			frame-master = <&dailink0_master>;
5462306a36Sopenharmony_ci			format = "i2s";
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_ci			cpu {
5762306a36Sopenharmony_ci				sound-dai = <&sai6>;
5862306a36Sopenharmony_ci			};
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ci			dailink0_master: codec {
6162306a36Sopenharmony_ci				sound-dai = <&wm8904>;
6262306a36Sopenharmony_ci			};
6362306a36Sopenharmony_ci		};
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ci		simple-audio-card,dai-link@1 {
6662306a36Sopenharmony_ci			reg = <1>;
6762306a36Sopenharmony_ci			bitclock-master = <&dailink1_master>;
6862306a36Sopenharmony_ci			frame-master = <&dailink1_master>;
6962306a36Sopenharmony_ci			format = "i2s";
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci			cpu {
7262306a36Sopenharmony_ci				sound-dai = <&sai5>;
7362306a36Sopenharmony_ci			};
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci			dailink1_master: codec {
7662306a36Sopenharmony_ci				sound-dai = <&wm8904>;
7762306a36Sopenharmony_ci			};
7862306a36Sopenharmony_ci		};
7962306a36Sopenharmony_ci	};
8062306a36Sopenharmony_ci};
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_ci&dspi2 {
8362306a36Sopenharmony_ci	flash@0 {
8462306a36Sopenharmony_ci		compatible = "jedec,spi-nor";
8562306a36Sopenharmony_ci		m25p,fast-read;
8662306a36Sopenharmony_ci		spi-max-frequency = <100000000>;
8762306a36Sopenharmony_ci		reg = <0>;
8862306a36Sopenharmony_ci	};
8962306a36Sopenharmony_ci};
9062306a36Sopenharmony_ci
9162306a36Sopenharmony_ci&i2c3 {
9262306a36Sopenharmony_ci	eeprom@57 {
9362306a36Sopenharmony_ci		compatible = "atmel,24c64";
9462306a36Sopenharmony_ci		reg = <0x57>;
9562306a36Sopenharmony_ci		pagesize = <32>;
9662306a36Sopenharmony_ci	};
9762306a36Sopenharmony_ci};
9862306a36Sopenharmony_ci
9962306a36Sopenharmony_ci&i2c4 {
10062306a36Sopenharmony_ci	status = "okay";
10162306a36Sopenharmony_ci
10262306a36Sopenharmony_ci	wm8904: audio-codec@1a {
10362306a36Sopenharmony_ci		#sound-dai-cells = <0>;
10462306a36Sopenharmony_ci		compatible = "wlf,wm8904";
10562306a36Sopenharmony_ci		reg = <0x1a>;
10662306a36Sopenharmony_ci		clocks = <&mclk>;
10762306a36Sopenharmony_ci		clock-names = "mclk";
10862306a36Sopenharmony_ci		assigned-clocks = <&mclk>;
10962306a36Sopenharmony_ci		assigned-clock-rates = <1250000>;
11062306a36Sopenharmony_ci	};
11162306a36Sopenharmony_ci};
11262306a36Sopenharmony_ci
11362306a36Sopenharmony_ci&sai5 {
11462306a36Sopenharmony_ci	status = "okay";
11562306a36Sopenharmony_ci};
11662306a36Sopenharmony_ci
11762306a36Sopenharmony_ci&sai6 {
11862306a36Sopenharmony_ci	status = "okay";
11962306a36Sopenharmony_ci};
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci&soc {
12262306a36Sopenharmony_ci	mclk: clock-mclk@f130080 {
12362306a36Sopenharmony_ci		compatible = "fsl,vf610-sai-clock";
12462306a36Sopenharmony_ci		reg = <0x0 0xf130080 0x0 0x80>;
12562306a36Sopenharmony_ci		clocks = <&clockgen QORIQ_CLK_PLATFORM_PLL
12662306a36Sopenharmony_ci				    QORIQ_CLK_PLL_DIV(2)>;
12762306a36Sopenharmony_ci		#clock-cells = <0>;
12862306a36Sopenharmony_ci	};
12962306a36Sopenharmony_ci};
130