diff --git a/raspberry-pi/overlays/default.nix b/raspberry-pi/overlays/default.nix index 2668b44..ca10ab1 100644 --- a/raspberry-pi/overlays/default.nix +++ b/raspberry-pi/overlays/default.nix @@ -2,9 +2,9 @@ imports = [ ./dtb-audremap.nix ./dtb-cpu-revision.nix - ./dtb-disable-pcie.nix - ./dtb-disable-genet.nix - ./dtb-panel-uc.nix + ./dtb-cpi-disable-pcie.nix + ./dtb-cpi-disable-genet.nix + ./dtb-cpi-uconsole.nix ./dtb-cpi-pmu.nix ./dtb-cpi-i2c1.nix ./dtb-cpi-bluetooth.nix diff --git a/raspberry-pi/overlays/dtb-panel-uc.nix b/raspberry-pi/overlays/dtb-cpi-disable-genet.nix similarity index 65% rename from raspberry-pi/overlays/dtb-panel-uc.nix rename to raspberry-pi/overlays/dtb-cpi-disable-genet.nix index 5c5187e..fa32e6e 100644 --- a/raspberry-pi/overlays/dtb-panel-uc.nix +++ b/raspberry-pi/overlays/dtb-cpi-disable-genet.nix @@ -4,13 +4,13 @@ ... }: let inherit (lib) mkEnableOption mkIf mkMerge mkOption types; - cfg = config.hardware.raspberry-pi."4".overlays.panel-uc; + cfg = config.hardware.raspberry-pi."4".overlays.cpi-disable-genet; in { - options.hardware.raspberry-pi."4".overlays.panel-uc = { + options.hardware.raspberry-pi."4".overlays.cpi-disable-genet = { enable = mkEnableOption ''overlay enable''; name = mkOption { type = types.str; - default = "panel-uc"; + default = "cpi-disable-genet"; }; }; @@ -21,7 +21,7 @@ in { { name = "${cfg.name}"; filter = "bcm2711-rpi-cm4.dtb"; - dtsFile = ./source/panel-uc.dts; + dtsFile = ./source/cpi-disable-genet.dts; } ]; }; diff --git a/raspberry-pi/overlays/dtb-disable-genet.nix b/raspberry-pi/overlays/dtb-cpi-disable-pcie.nix similarity index 66% rename from raspberry-pi/overlays/dtb-disable-genet.nix rename to raspberry-pi/overlays/dtb-cpi-disable-pcie.nix index 221153e..3aea75f 100644 --- a/raspberry-pi/overlays/dtb-disable-genet.nix +++ b/raspberry-pi/overlays/dtb-cpi-disable-pcie.nix @@ -4,13 +4,13 @@ ... }: let inherit (lib) mkEnableOption mkIf mkMerge mkOption types; - cfg = config.hardware.raspberry-pi."4".overlays.disable-genet; + cfg = config.hardware.raspberry-pi."4".overlays.cpi-disable-pcie; in { - options.hardware.raspberry-pi."4".overlays.disable-genet = { + options.hardware.raspberry-pi."4".overlays.cpi-disable-pcie = { enable = mkEnableOption ''overlay enable''; name = mkOption { type = types.str; - default = "disable-genet"; + default = "cpi-disable-pcie"; }; }; @@ -21,7 +21,7 @@ in { { name = "${cfg.name}"; filter = "bcm2711-rpi-cm4.dtb"; - dtsFile = ./source/disable-genet.dts; + dtsFile = ./source/cpi-disable-pcie.dts; } ]; }; diff --git a/raspberry-pi/overlays/dtb-disable-pcie.nix b/raspberry-pi/overlays/dtb-cpi-uconsole.nix similarity index 67% rename from raspberry-pi/overlays/dtb-disable-pcie.nix rename to raspberry-pi/overlays/dtb-cpi-uconsole.nix index 02d8fe0..95ed719 100644 --- a/raspberry-pi/overlays/dtb-disable-pcie.nix +++ b/raspberry-pi/overlays/dtb-cpi-uconsole.nix @@ -4,13 +4,13 @@ ... }: let inherit (lib) mkEnableOption mkIf mkMerge mkOption types; - cfg = config.hardware.raspberry-pi."4".overlays.disable-pcie; + cfg = config.hardware.raspberry-pi."4".overlays.cpi-uconsole; in { - options.hardware.raspberry-pi."4".overlays.disable-pcie = { + options.hardware.raspberry-pi."4".overlays.cpi-uconsole = { enable = mkEnableOption ''overlay enable''; name = mkOption { type = types.str; - default = "disable-pcie"; + default = "cpi-uconsole"; }; }; @@ -21,7 +21,7 @@ in { { name = "${cfg.name}"; filter = "bcm2711-rpi-cm4.dtb"; - dtsFile = ./source/disable-pcie.dts; + dtsFile = ./source/cpi-uconsole.dts; } ]; }; diff --git a/raspberry-pi/overlays/source/disable-genet.dts b/raspberry-pi/overlays/source/cpi-disable-genet.dts similarity index 100% rename from raspberry-pi/overlays/source/disable-genet.dts rename to raspberry-pi/overlays/source/cpi-disable-genet.dts diff --git a/raspberry-pi/overlays/source/disable-pcie.dts b/raspberry-pi/overlays/source/cpi-disable-pcie.dts similarity index 100% rename from raspberry-pi/overlays/source/disable-pcie.dts rename to raspberry-pi/overlays/source/cpi-disable-pcie.dts diff --git a/raspberry-pi/overlays/source/cpi-uconsole.dts b/raspberry-pi/overlays/source/cpi-uconsole.dts new file mode 100644 index 0000000..02d0e8d --- /dev/null +++ b/raspberry-pi/overlays/source/cpi-uconsole.dts @@ -0,0 +1,170 @@ +/dts-v1/; +/plugin/; + +/{ + compatible = "brcm,bcm2711"; + + fragment@10 { + target = <&i2c0if>; + __overlay__ { + #address-cells = <1>; + #size-cells = <0>; + pinctrl-0 = <&i2c0_pins>; + pinctrl-names = "default"; + status = "okay"; + + axp22x: pmic@34 { + interrupt-controller; + #interrupt-cells = <1>; + compatible = "x-powers,axp221"; + reg = <0x34>; /* i2c address */ + interrupt-parent = <&gpio>; + interrupts = <2 8>; /* IRQ_TYPE_EDGE_FALLING */ + irq-gpios = <&gpio 2 0>; + + regulators { + + x-powers,dcdc-freq = <3000>; + + reg_dcdc3: dcdc3 { + regulator-name = "sys-1v8"; + regulator-always-on; + regulator-min-microvolt = <1800000>; + regulator-max-microvolt = <1800000>; + }; + + reg_aldo1: aldo1 { + regulator-always-on; + regulator-min-microvolt = <3300000>; + regulator-max-microvolt = <3300000>; + regulator-name = "audio-vdd"; + }; + + reg_aldo2: aldo2 { + regulator-min-microvolt = <3300000>; + regulator-max-microvolt = <3300000>; + regulator-name = "display-vcc"; + }; + + reg_dldo2: dldo2 { + regulator-always-on; + regulator-min-microvolt = <3300000>; + regulator-max-microvolt = <3300000>; + regulator-name = "dldo2"; + }; + + reg_dldo3: dldo3 { + regulator-always-on; + regulator-min-microvolt = <3300000>; + regulator-max-microvolt = <3300000>; + regulator-name = "dldo3"; + }; + + reg_dldo4: dldo4 { + regulator-always-on; + regulator-min-microvolt = <3300000>; + regulator-max-microvolt = <3300000>; + regulator-name = "dldo4"; + }; + + }; + + battery_power_supply: battery-power-supply { + compatible = "x-powers,axp221-battery-power-supply"; + monitored-battery = <&battery>; + }; + + ac_power_supply: ac_power_supply { + compatible = "x-powers,axp221-ac-power-supply"; + }; + + }; + }; + }; + + fragment@11 { + target = <&i2c0if>; + __overlay__ { + compatible = "brcm,bcm2708-i2c"; + }; + }; + + fragment@12 { + target-path = "/aliases"; + __overlay__ { + i2c0 = "/soc/i2c@7e205000"; + }; + }; + + fragment@13 { + target-path = "/"; + __overlay__ { + battery: battery@0 { + compatible = "simple-battery"; + device-chemistry = "lithium-ion"; + constant-charge-current-max-microamp = <2100000>; + voltage-max-design-microvolt = <4200000>; + re-charge-voltage-microvolt = <4000000>; + // adjust the following params according to your battery specs + voltage-min-design-microvolt = <3300000>; + energy-full-design-microwatt-hours = <24790000>; // 2x3350mAh * 3.7v + charge-full-design-microamp-hours = <6700000>; // 2x3350mAh + }; + }; + }; + + fragment@90 { + target=<&dsi1>; + __overlay__ { + #address-cells = <1>; + #size-cells = <0>; + status = "okay"; + + port { + dsi_out_port: endpoint { + remote-endpoint = <&panel_dsi_port>; + }; + }; + + panel_cwu50: panel@0 { + compatible = "clockwork,cwu50"; + reg = <0>; + reset-gpio = <&gpio 8 1>; + backlight = <&ocp8178_backlight>; + rotation = <90>; + iovcc-supply = <®_dcdc3>; + vci-supply = <®_aldo2>; + + port { + panel_dsi_port: endpoint { + remote-endpoint = <&dsi_out_port>; + }; + }; + }; + }; + }; + + fragment@91 { + target-path = "/"; + __overlay__ { + ocp8178_backlight: backlight@0 { + compatible = "ocp8178-backlight"; + backlight-control-gpios = <&gpio 9 0>; + default-brightness = <5>; + }; + }; + }; + + fragment@92 { + target-path = "/"; + __overlay__ { + audio_amplifier: audio-amplifier { + compatible = "simple-amplifier-switch"; + sw-gpios = <&gpio 10 1>; /* GPIO10, GPIO_ACTIVE_LOW */ + outputs-gpios = <&gpio 11 0>; /* GPIO11, GPIO_ACTIVE_HIGH */ + // vdd-supply = <&uc_reg_5v0>; /* FIXME */ + }; + }; + }; + +}; diff --git a/raspberry-pi/overlays/source/panel-uc.dts b/raspberry-pi/overlays/source/panel-uc.dts deleted file mode 100644 index 2a656d9..0000000 --- a/raspberry-pi/overlays/source/panel-uc.dts +++ /dev/null @@ -1,47 +0,0 @@ -/dts-v1/; -/plugin/; - -/{ - compatible = "brcm,bcm2711"; - - fragment@0 { - target=<&dsi1>; - __overlay__ { - #address-cells = <1>; - #size-cells = <0>; - status = "okay"; - - port { - dsi_out_port: endpoint { - remote-endpoint = <&panel_dsi_port>; - }; - }; - - panel_cwu50: panel@0 { - compatible = "cw,cwu50"; - reg = <0>; - reset-gpio = <&gpio 8 1>; - backlight = <&ocp8178_backlight>; - rotation = <90>; - - port { - panel_dsi_port: endpoint { - remote-endpoint = <&dsi_out_port>; - }; - }; - }; - }; - }; - - fragment@1 { - target-path = "/"; - __overlay__ { - ocp8178_backlight: backlight@0 { - compatible = "ocp8178-backlight"; - backlight-control-gpios = <&gpio 9 0>; - default-brightness = <5>; - }; - }; - }; - -};