Skip to content

Add overlay for mcp3008 adc #1818

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 2 commits into from
Jan 27, 2017
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions arch/arm/boot/dts/overlays/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ dtbo-$(RPI_DT_OVERLAYS) += mcp23017.dtbo
dtbo-$(RPI_DT_OVERLAYS) += mcp23s17.dtbo
dtbo-$(RPI_DT_OVERLAYS) += mcp2515-can0.dtbo
dtbo-$(RPI_DT_OVERLAYS) += mcp2515-can1.dtbo
dtbo-$(RPI_DT_OVERLAYS) += mcp3008.dtbo
dtbo-$(RPI_DT_OVERLAYS) += mmc.dtbo
dtbo-$(RPI_DT_OVERLAYS) += mz61581.dtbo
dtbo-$(RPI_DT_OVERLAYS) += pi3-act-led.dtbo
Expand Down
9 changes: 9 additions & 0 deletions arch/arm/boot/dts/overlays/README
Original file line number Diff line number Diff line change
Expand Up @@ -736,6 +736,15 @@ Params: oscillator Clock frequency for the CAN controller (Hz)
interrupt GPIO for interrupt signal


Name: mcp3008
Info: Configures MCP3008 A/D converters
For devices on spi1 or spi2, the interfaces should be enabled
with one of the spi1-1/2/3cs and/or spi2-1/2/3cs overlays.
Load: dtoverlay=mcp3008,<param>[=<val>]
Params: spi<n>-<m>-present boolean, configure device at spi<n>, cs<m>
spi<n>-<m>-speed integer, set the spi bus speed for this device


Name: mmc
Info: Selects the bcm2835-mmc SD/MMC driver, optionally with overclock
Load: dtoverlay=mmc,<param>=<val>
Expand Down
205 changes: 205 additions & 0 deletions arch/arm/boot/dts/overlays/mcp3008-overlay.dts
Original file line number Diff line number Diff line change
@@ -0,0 +1,205 @@
/*
* Device tree overlay for Microchip mcp3008 10-Bit A/D Converters
*/

/dts-v1/;
/plugin/;

/ {
compatible = "brcm,bcm2835", "brcm,bcm2708", "brcm,bcm2709";

fragment@0 {
target = <&spidev0>;
__dormant__ {
status = "disabled";
};
};

fragment@1 {
target = <&spidev1>;
__dormant__ {
status = "disabled";
};
};

fragment@2 {
target-path = "spi1/spidev@0";
__dormant__ {
status = "disabled";
};
};

fragment@3 {
target-path = "spi1/spidev@1";
__dormant__ {
status = "disabled";
};
};

fragment@4 {
target-path = "spi1/spidev@2";
__dormant__ {
status = "disabled";
};
};

fragment@5 {
target-path = "spi2/spidev@0";
__dormant__ {
status = "disabled";
};
};

fragment@6 {
target-path = "spi2/spidev@1";
__dormant__ {
status = "disabled";
};
};

fragment@7 {
target-path = "spi2/spidev@2";
__dormant__ {
status = "disabled";
};
};

fragment@8 {
target = <&spi0>;
__dormant__ {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;

mcp3008_00: mcp3008@0 {
compatible = "mcp3008";
reg = <0>;
spi-max-frequency = <1600000>;
};
};
};

fragment@9 {
target = <&spi0>;
__dormant__ {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;

mcp3008_01: mcp3008@1 {
compatible = "mcp3008";
reg = <1>;
spi-max-frequency = <1600000>;
};
};
};

fragment@10 {
target = <&spi1>;
__dormant__ {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;

mcp3008_10: mcp3008@0 {
compatible = "mcp3008";
reg = <0>;
spi-max-frequency = <1600000>;
};
};
};

fragment@11 {
target = <&spi1>;
__dormant__ {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;

mcp3008_11: mcp3008@1 {
compatible = "mcp3008";
reg = <1>;
spi-max-frequency = <1600000>;
};
};
};

fragment@12 {
target = <&spi1>;
__dormant__ {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;

mcp3008_12: mcp3008@2 {
compatible = "mcp3008";
reg = <2>;
spi-max-frequency = <1600000>;
};
};
};

fragment@13 {
target = <&spi2>;
__dormant__ {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;

mcp3008_20: mcp3008@0 {
compatible = "mcp3008";
reg = <0>;
spi-max-frequency = <1600000>;
};
};
};

fragment@14 {
target = <&spi2>;
__dormant__ {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;

mcp3008_21: mcp3008@1 {
compatible = "mcp3008";
reg = <1>;
spi-max-frequency = <1600000>;
};
};
};

fragment@15 {
target = <&spi2>;
__dormant__ {
status = "okay";
#address-cells = <1>;
#size-cells = <0>;

mcp3008_22: mcp3008@2 {
compatible = "mcp3008";
reg = <2>;
spi-max-frequency = <1600000>;
};
};
};

__overrides__ {
spi0-0-present = <0>, "+0+8";
spi0-1-present = <0>, "+1+9";
spi1-0-present = <0>, "+2+10";
spi1-1-present = <0>, "+3+11";
spi1-2-present = <0>, "+4+12";
spi2-0-present = <0>, "+5+13";
spi2-1-present = <0>, "+6+14";
spi2-2-present = <0>, "+7+15";
spi0-0-speed = <&mcp3008_00>, "spi-max-frequency:0";
spi0-1-speed = <&mcp3008_01>, "spi-max-frequency:0";
spi1-0-speed = <&mcp3008_10>, "spi-max-frequency:0";
spi1-1-speed = <&mcp3008_11>, "spi-max-frequency:0";
spi1-2-speed = <&mcp3008_12>, "spi-max-frequency:0";
spi2-0-speed = <&mcp3008_20>, "spi-max-frequency:0";
spi2-1-speed = <&mcp3008_21>, "spi-max-frequency:0";
spi2-2-speed = <&mcp3008_22>, "spi-max-frequency:0";
};
};