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@xxxxxxxxx> --- 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 -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html