Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 187642
b: refs/heads/master
c: 91492b4
h: refs/heads/master
v: v3
  • Loading branch information
Maurus Cuelenaere authored and Ben Dooks committed Feb 3, 2010
1 parent 9ae4cec commit 75faff2
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 6 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: cf9814eb6d83f066d5db63f4144598e9c6ca2951
refs/heads/master: 91492b4a04586e7cb191c72de9d1b22545a3ce16
24 changes: 19 additions & 5 deletions trunk/arch/arm/plat-samsung/adc.c
Original file line number Diff line number Diff line change
Expand Up @@ -262,6 +262,7 @@ static irqreturn_t s3c_adc_irq(int irq, void *pw)
{
struct adc_device *adc = pw;
struct s3c_adc_client *client = adc->cur;
enum s3c_cpu_type cpu = platform_get_device_id(adc->pdev)->driver_data;
unsigned long flags;
unsigned data0, data1;

Expand All @@ -276,9 +277,17 @@ static irqreturn_t s3c_adc_irq(int irq, void *pw)

client->nr_samples--;

if (cpu == TYPE_S3C64XX) {
/* S3C64XX ADC resolution is 12-bit */
data0 &= 0xfff;
data1 &= 0xfff;
} else {
data0 &= 0x3ff;
data1 &= 0x3ff;
}

if (client->convert_cb)
(client->convert_cb)(client, data0 & 0x3ff, data1 & 0x3ff,
&client->nr_samples);
(client->convert_cb)(client, data0, data1, &client->nr_samples);

if (client->nr_samples > 0) {
/* fire another conversion for this */
Expand All @@ -295,7 +304,7 @@ static irqreturn_t s3c_adc_irq(int irq, void *pw)
}

exit:
if (platform_get_device_id(adc->pdev)->driver_data == TYPE_S3C64XX) {
if (cpu == TYPE_S3C64XX) {
/* Clear ADC interrupt */
writel(0, adc->regs + S3C64XX_ADCCLRINT);
}
Expand All @@ -308,6 +317,7 @@ static int s3c_adc_probe(struct platform_device *pdev)
struct adc_device *adc;
struct resource *regs;
int ret;
unsigned tmp;

adc = kzalloc(sizeof(struct adc_device), GFP_KERNEL);
if (adc == NULL) {
Expand Down Expand Up @@ -354,8 +364,12 @@ static int s3c_adc_probe(struct platform_device *pdev)

clk_enable(adc->clk);

writel(adc->prescale | S3C2410_ADCCON_PRSCEN,
adc->regs + S3C2410_ADCCON);
tmp = adc->prescale | S3C2410_ADCCON_PRSCEN;
if (platform_get_device_id(pdev)->driver_data == TYPE_S3C64XX) {
/* Enable 12-bit ADC resolution */
tmp |= S3C64XX_ADCCON_RESSEL;
}
writel(tmp, adc->regs + S3C2410_ADCCON);

dev_info(dev, "attached adc driver\n");

Expand Down
1 change: 1 addition & 0 deletions trunk/arch/arm/plat-samsung/include/plat/regs-adc.h
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@


/* ADCCON Register Bits */
#define S3C64XX_ADCCON_RESSEL (1<<16)
#define S3C2410_ADCCON_ECFLG (1<<15)
#define S3C2410_ADCCON_PRSCEN (1<<14)
#define S3C2410_ADCCON_PRSCVL(x) (((x)&0xFF)<<6)
Expand Down

0 comments on commit 75faff2

Please sign in to comment.