mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-06 02:24:14 +08:00
arm64: dts: qcom: sc7280: eDP for herobrine boards
Add eDP support to herobrine boards, splitting up amongst the different files as makes sense. Rationale for the current split of things: * The eDP connector itself is on qcard. However, not all devices with a qcard will use an eDP panel. Some might use MIPI and, presumably, someone could build a device with qcard that had no display at all. * The qcard provides a PWM for backlight that goes to the eDP connector. This PWM is also provided to the board and it's expected that it would be used as the backlight PWM even for herobrine devices with MIPI displays. * It's currently assumed that all herobrine boards will have some sort of display, either MIPI or eDP (but not both). * We will assume herobrine-rev1 has eDP. The schematics allow for a MIPI panel to be hooked up but, aside from some testing, nobody is doing this and most boards don't have all the parts stuffed for it. The two panels would also share a PWM for backlight, which is weird. * herobrine-villager and herobrine-hoglin (crd) also have eDP. * herobrine-hoglin (crd) has slightly different regulator setup for the backlight. It's expected that this is unique to this board. See comments in the dts file. * There are some regulators that are defined in the qcard schematic but provided by the board like "vreg_edp_bl" and "vreg_edp_3p3". While we could put references to these regulators straight in the qcard.dtsi file, this would force someone using qcard that didn't provide those regulators to provide a dummy or do an ugly /delete-node/. Instead, we'll add references in herobrine.dtsi. Signed-off-by: Douglas Anderson <dianders@chromium.org> Reviewed-by: Abhinav Kumar <quic_abhinavk@quicinc.com> Reviewed-by: Stephen Boyd <swboyd@chromium.org> Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org> Link: https://lore.kernel.org/r/20220426124053.v2.1.Iedd71976a78d53c301ce0134832de95a989c9195@changeid
This commit is contained in:
parent
11a3f3dc2c
commit
366a0a194b
@ -12,6 +12,27 @@
|
||||
/ {
|
||||
model = "Qualcomm Technologies, Inc. sc7280 CRD platform (rev5+)";
|
||||
compatible = "google,hoglin", "qcom,sc7280";
|
||||
|
||||
/* FIXED REGULATORS */
|
||||
|
||||
/*
|
||||
* On most herobrine boards PPVAR_SYS directly provides VREG_EDP_BL.
|
||||
* However, on CRD there's an extra regulator in the way. Since this
|
||||
* is expected to be uncommon, we'll leave the "vreg_edp_bl" label
|
||||
* in the baseboard herobrine.dtsi point at "ppvar_sys" and then
|
||||
* make a "_crd" specific version here.
|
||||
*/
|
||||
vreg_edp_bl_crd: vreg-edp-bl-crd-regulator {
|
||||
compatible = "regulator-fixed";
|
||||
regulator-name = "vreg_edp_bl_crd";
|
||||
|
||||
gpio = <&pm8350c_gpios 6 GPIO_ACTIVE_HIGH>;
|
||||
enable-active-high;
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&edp_bl_reg_en>;
|
||||
|
||||
vin-supply = <&ppvar_sys>;
|
||||
};
|
||||
};
|
||||
|
||||
/* ADDITIONS TO NODES DEFINED IN PARENT DEVICE TREE FILES */
|
||||
@ -81,6 +102,14 @@ ap_ts_pen_1v8: &i2c13 {
|
||||
};
|
||||
};
|
||||
|
||||
&mdss_edp {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&mdss_edp_phy {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
/* For nvme */
|
||||
&pcie1 {
|
||||
status = "okay";
|
||||
@ -91,6 +120,10 @@ ap_ts_pen_1v8: &i2c13 {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&pm8350c_pwm_backlight {
|
||||
power-supply = <&vreg_edp_bl_crd>;
|
||||
};
|
||||
|
||||
/* For eMMC */
|
||||
&sdhc_1 {
|
||||
status = "okay";
|
||||
@ -121,6 +154,13 @@ ap_ts_pen_1v8: &i2c13 {
|
||||
"PMIC_EDP_BL_EN",
|
||||
"PMIC_EDP_BL_PWM",
|
||||
"";
|
||||
|
||||
edp_bl_reg_en: edp-bl-reg-en {
|
||||
pins = "gpio6";
|
||||
function = "normal";
|
||||
bias-disable;
|
||||
qcom,drive-strength = <PMIC_GPIO_STRENGTH_LOW>;
|
||||
};
|
||||
};
|
||||
|
||||
&tlmm {
|
||||
|
@ -100,6 +100,14 @@ ts_i2c: &i2c13 {
|
||||
};
|
||||
};
|
||||
|
||||
&mdss_edp {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&mdss_edp_phy {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
/* For nvme */
|
||||
&pcie1 {
|
||||
status = "okay";
|
||||
|
@ -58,6 +58,14 @@ ap_tp_i2c: &i2c0 {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&mdss_edp {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&mdss_edp_phy {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
/* For nvme */
|
||||
&pcie1 {
|
||||
status = "okay";
|
||||
|
@ -367,6 +367,11 @@ vreg_edp_3p3: &pp3300_left_in_mlb {};
|
||||
|
||||
/* ADDITIONS TO NODES DEFINED IN PARENT DEVICE TREE FILES */
|
||||
|
||||
&edp_panel {
|
||||
/* Our board provides power to the qcard for the eDP panel. */
|
||||
power-supply = <&vreg_edp_3p3>;
|
||||
};
|
||||
|
||||
ap_sar_sensor_i2c: &i2c1 {
|
||||
clock-frequency = <400000>;
|
||||
status = "disabled";
|
||||
@ -420,6 +425,14 @@ ap_i2c_tpm: &i2c14 {
|
||||
};
|
||||
};
|
||||
|
||||
&mdss {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&mdss_mdp {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
/* NVMe drive, enabled on a per-board basis */
|
||||
&pcie1 {
|
||||
pinctrl-names = "default";
|
||||
@ -429,6 +442,17 @@ ap_i2c_tpm: &i2c14 {
|
||||
vddpe-3v3-supply = <&pp3300_ssd>;
|
||||
};
|
||||
|
||||
&pm8350c_pwm {
|
||||
status = "okay";
|
||||
};
|
||||
|
||||
&pm8350c_pwm_backlight {
|
||||
status = "okay";
|
||||
|
||||
/* Our board provides power to the qcard for the backlight */
|
||||
power-supply = <&vreg_edp_bl>;
|
||||
};
|
||||
|
||||
&pmk8350_rtc {
|
||||
status = "disabled";
|
||||
};
|
||||
|
@ -29,6 +29,16 @@
|
||||
serial0 = &uart5;
|
||||
serial1 = &uart7;
|
||||
};
|
||||
|
||||
pm8350c_pwm_backlight: backlight {
|
||||
compatible = "pwm-backlight";
|
||||
status = "disabled";
|
||||
|
||||
enable-gpios = <&pm8350c_gpios 7 GPIO_ACTIVE_HIGH>;
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&pmic_edp_bl_en>;
|
||||
pwms = <&pm8350c_pwm 3 65535>;
|
||||
};
|
||||
};
|
||||
|
||||
&apps_rsc {
|
||||
@ -293,11 +303,50 @@
|
||||
modem-init;
|
||||
};
|
||||
|
||||
/* NOTE: Not all Qcards have eDP connector stuffed */
|
||||
&mdss_edp {
|
||||
vdda-0p9-supply = <&vdd_a_edp_0_0p9>;
|
||||
vdda-1p2-supply = <&vdd_a_edp_0_1p2>;
|
||||
|
||||
aux-bus {
|
||||
edp_panel: panel {
|
||||
compatible = "edp-panel";
|
||||
|
||||
backlight = <&pm8350c_pwm_backlight>;
|
||||
|
||||
ports {
|
||||
#address-cells = <1>;
|
||||
#size-cells = <0>;
|
||||
port@0 {
|
||||
reg = <0>;
|
||||
edp_panel_in: endpoint {
|
||||
remote-endpoint = <&mdss_edp_out>;
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
&mdss_edp_out {
|
||||
remote-endpoint = <&edp_panel_in>;
|
||||
};
|
||||
|
||||
&mdss_edp_phy {
|
||||
vdda-pll-supply = <&vdd_a_edp_0_0p9>;
|
||||
vdda-phy-supply = <&vdd_a_edp_0_1p2>;
|
||||
};
|
||||
|
||||
&pcie1_phy {
|
||||
vdda-phy-supply = <&vreg_l10c_0p88>;
|
||||
vdda-pll-supply = <&vreg_l6b_1p2>;
|
||||
};
|
||||
|
||||
&pm8350c_pwm {
|
||||
pinctrl-names = "default";
|
||||
pinctrl-0 = <&pmic_edp_bl_pwm>;
|
||||
};
|
||||
|
||||
&pmk8350_vadc {
|
||||
pmk8350-die-temp@3 {
|
||||
reg = <PMK8350_ADC7_DIE_TEMP>;
|
||||
@ -383,6 +432,11 @@ mos_bt_uart: &uart7 {
|
||||
* baseboard or board device tree, not here.
|
||||
*/
|
||||
|
||||
/* No external pull for eDP HPD, so set the internal one. */
|
||||
&edp_hot_plug_det {
|
||||
bias-pull-down;
|
||||
};
|
||||
|
||||
/*
|
||||
* For ts_i2c
|
||||
*
|
||||
|
Loading…
Reference in New Issue
Block a user