[[PATCH v2] 1/2] Altera Modular ADC driver device binding

From: Chee Nouk Phoo
Date: Thu Sep 03 2015 - 06:17:43 EST


From: Chee Nouk Phoon <cnphoon@xxxxxxxxxx>

Altera Modular ADC is soft IP that wraps the hardened ADC block in a Max10
device. It can be configured to dual ADC mode that supports two channel
synchronous sampling or independent single ADCs. ADC sampled values will be
written into memory slots in sequence determined by a user configurable
sequencer block.

This patch adds Altera Modular ADC driver device tree binding

Signed-off-by: Chee Nouk Phoon <cnphoon@xxxxxxxxxx>
---
.../bindings/iio/adc/altr,modular-adc.txt | 63 ++++++++++++++++++++
1 files changed, 63 insertions(+), 0 deletions(-)
create mode 100644 Documentation/devicetree/bindings/iio/adc/altr,modular-adc.txt

diff --git a/Documentation/devicetree/bindings/iio/adc/altr,modular-adc.txt b/Documentation/devicetree/bindings/iio/adc/altr,modular-adc.txt
new file mode 100644
index 0000000..faafcac
--- /dev/null
+++ b/Documentation/devicetree/bindings/iio/adc/altr,modular-adc.txt
@@ -0,0 +1,63 @@
+Altera Modular (Dual) ADC
+
+This binding document describes both Altera Modular ADC and Altera Modular Dual
+ADC. Both options can be configured during generation time in Qsys. This driver
+only supports standard sequencer with Avalon-MM sample storage with up to 64
+memory slots.
+
+Required properties:
+- compatible: must be one of the following strings
+ "altr,modular-adc-1.0": single ADC configuration
+ "altr,modular-dual-adc-1.0": dual ADC configuration
+
+- reg: Address and length of the register set for the device. It contains the
+ information of registers in the same order as described by reg-names
+
+- reg-names: Should contain the reg names
+ "sequencer_csr": register region for adc sequencer block
+ "sample_store_csr": register region for sample store block
+
+- interrupts: interrupt line for ADC
+
+- altr,adc-mode : ADC configuration
+ 1: single ADC mode
+ 2: dual ADC mode
+
+- altr,adc-slot-count : specify number of conversion slot in use
+
+- altr,adc<ADC index>-slot-sequence-<slot index>: specify ADC channel
+ conversion sequence
+ <ADC index>: instantiated ADC number
+ <slot index>: slot index for ADC memory slot
+
+- altr,adc-number : specify ADC number when single ADC mode is selected
+ 1: 1st ADC
+ 2: 2nd ACD
+
+Example: single ADC
+modular_adc_0: adc@0x20000200 {
+ compatible = "altr,modular-adc";
+ reg = <0x20000000 0x00000008>,
+ <0x20000200 0x00000200>;
+ reg-names = "sequencer_csr", "sample_store_csr";
+ interrupt-parent = <&cpu>;
+ interrupts = <8>;
+ altr,adc-mode = <1>;
+ altr,adc-slot-count = <2>;
+ altr,adc1-slot-sequence-1 = <1>;
+ altr,adc-number = <1>;
+};
+
+Example: dual ADC
+modular_adc_1: adc@0x18002200 {
+ compatible = "altr,modular-dual-adc";
+ reg = <0x18002000 0x00000008>,
+ <0x18002200 0x00000200>;
+ reg-names = "sequencer_csr", "sample_store_csr";
+ interrupt-parent = <&cpu>;
+ interrupts = <8>;
+ altr,adc-mode = <2>;
+ altr,adc-slot-count = <1>;
+ altr,adc1-slot-sequence-1 = <6>;
+ altr,adc2-slot-sequence-1 = <6>;
+};
\ No newline at end of file
--
1.7.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/