[PATCH v2 2/2] s3c-adc: describe features via quirk constants
Heiko Stübner
heiko at sntech.de
Wed Sep 28 02:43:15 EDT 2011
The adc blocks of S3C2410 through S5P have a multitude of
quirks, i.e. moved bits or whole new registers.
This patch tries to describe these individual features
through constants which can be used to describe an adc.
As SoCs sometimes share only some of these quirks defining
TYPE_ADCVx values for each one wouldn't scale well when
adding more variants.
Signed-off-by: Heiko Stuebner <heiko at sntech.de>
---
changes since v1: add spaces around <<
arch/arm/plat-samsung/adc.c | 29 +++++++++++++++++++++++++++++
1 files changed, 29 insertions(+), 0 deletions(-)
diff --git a/arch/arm/plat-samsung/adc.c b/arch/arm/plat-samsung/adc.c
index ee8deef..4fc4deb 100644
--- a/arch/arm/plat-samsung/adc.c
+++ b/arch/arm/plat-samsung/adc.c
@@ -45,6 +45,35 @@ enum s3c_cpu_type {
TYPE_ADCV3, /* S5PV210, S5PC110, EXYNOS4210 */
};
+/*
+ * Resolution of the ADC - 10 or 12 bit
+ */
+#define S3C_ADC_QUIRK_10BIT 0
+#define S3C_ADC_QUIRK_12BIT (1 << 0)
+
+/*
+ * 12bit ADC can switch resolution between 10 bit and 12 bit
+ * ADCCON bit 03 for S3C2416
+ * ADCCON bit 16 for S3C64XX and up
+ */
+#define S3C_ADC_QUIRK_RESSEL03 (1 << 1)
+#define S3C_ADC_QUIRK_RESSEL16 (1 << 2)
+
+/*
+ * Input channel select can either be in
+ * - reg ADCCON, bit for S3C24XX and S3C64XX
+ * - reg base+0x18 for 2443/2416/2450
+ * - reg base+0x1C for S5P
+ */
+#define S3C_ADC_QUIRK_MUXADCCON (1 << 3)
+#define S3C_ADC_QUIRK_MUX18 (1 << 4)
+#define S3C_ADC_QUIRK_MUX1C (1 << 5)
+
+/*
+ * CLRINT register on S3C64xx
+ */
+#define S3C_ADC_QUIRK_CLRINT (1 << 6)
+
struct s3c_adc_client {
struct platform_device *pdev;
struct list_head pend;
--
1.7.5.4
More information about the linux-arm-kernel
mailing list