hw/misc: Add support for ADC controller in Xilinx Zynq 7000
commit74fcbd22d20a2fbc1a47a7b00cce5bf98fd7be5f
authorGuenter Roeck <linux@roeck-us.net>
Thu, 12 Nov 2015 17:54:55 +0000 (12 09:54 -0800)
committerPeter Maydell <peter.maydell@linaro.org>
Thu, 12 Nov 2015 21:30:42 +0000 (12 21:30 +0000)
tree742001da3f35cd5a999fcccd7caeaa5cd52e6a1b
parentf3bcfc5663646f74e62fe9d3d8774b8f0adda7bf
hw/misc: Add support for ADC controller in Xilinx Zynq 7000

Add support for the Xilinx XADC core used in Zynq 7000.

References:
- Zynq-7000 All Programmable SoC Technical Reference Manual
- 7 Series FPGAs and Zynq-7000 All Programmable SoC XADC
  Dual 12-Bit 1 MSPS Analog-to-Digital Converter

Tested with Linux using QEMU machine xilinx-zynq-a9 with devicetree
files zynq-zc702.dtb and zynq-zc706.dtb, and kernel configuration
multi_v7_defconfig.

Reviewed-by: Alistair Francis <alistair.francis@xilinx.com>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
[ PC changes:
  * Changed macro names to match TRM where possible
  * Made programmers model macro scheme consistent
  * Dropped XADC_ZYNQ_ prefix on local macros
  * Fix ALM field width
  * Update threshold-comparison interrupts in _update_ints()
  * factored out DFIFO pushes into helper. Renamed to "push/pop"
  * Changed xadc_reg to 10 bits and added OOB check.
  * Reduced scope of MCTL reset to just stop channel coms.
  * Added dummy read data to write commands
  * Changed _ to - seperators in string names and filenames
  * Dropped ------------ in header comment
  * Catchall'ed _update_ints() in _write handler.
  * Minor whitespace changes.
  * Use ZYNQ_XADC_FIFO_DEPTH instead of ARRAY_SIZE()
]
Signed-off-by: Peter Crosthwaite <crosthwaite.peter@gmail.com>
Tested-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
hw/arm/xilinx_zynq.c
hw/misc/Makefile.objs
hw/misc/zynq-xadc.c [new file with mode: 0644]
include/hw/misc/zynq-xadc.h [new file with mode: 0644]