diff options
Diffstat (limited to 'drivers/iio/adc/xilinx-ams.c')
| -rw-r--r-- | drivers/iio/adc/xilinx-ams.c | 47 | 
1 files changed, 26 insertions, 21 deletions
| diff --git a/drivers/iio/adc/xilinx-ams.c b/drivers/iio/adc/xilinx-ams.c index 76dd0343f5f7..124470c92529 100644 --- a/drivers/iio/adc/xilinx-ams.c +++ b/drivers/iio/adc/xilinx-ams.c @@ -118,7 +118,7 @@  #define AMS_ALARM_THRESHOLD_OFF_10	0x10  #define AMS_ALARM_THRESHOLD_OFF_20	0x20 -#define AMS_ALARM_THR_DIRECT_MASK	BIT(1) +#define AMS_ALARM_THR_DIRECT_MASK	BIT(0)  #define AMS_ALARM_THR_MIN		0x0000  #define AMS_ALARM_THR_MAX		(BIT(16) - 1) @@ -389,6 +389,29 @@ static void ams_update_pl_alarm(struct ams *ams, unsigned long alarm_mask)  	ams_pl_update_reg(ams, AMS_REG_CONFIG3, AMS_REGCFG3_ALARM_MASK, cfg);  } +static void ams_unmask(struct ams *ams) +{ +	unsigned int status, unmask; + +	status = readl(ams->base + AMS_ISR_0); + +	/* Clear those bits which are not active anymore */ +	unmask = (ams->current_masked_alarm ^ status) & ams->current_masked_alarm; + +	/* Clear status of disabled alarm */ +	unmask |= ams->intr_mask; + +	ams->current_masked_alarm &= status; + +	/* Also clear those which are masked out anyway */ +	ams->current_masked_alarm &= ~ams->intr_mask; + +	/* Clear the interrupts before we unmask them */ +	writel(unmask, ams->base + AMS_ISR_0); + +	ams_update_intrmask(ams, ~AMS_ALARM_MASK, ~AMS_ALARM_MASK); +} +  static void ams_update_alarm(struct ams *ams, unsigned long alarm_mask)  {  	unsigned long flags; @@ -401,6 +424,7 @@ static void ams_update_alarm(struct ams *ams, unsigned long alarm_mask)  	spin_lock_irqsave(&ams->intr_lock, flags);  	ams_update_intrmask(ams, AMS_ISR0_ALARM_MASK, ~alarm_mask); +	ams_unmask(ams);  	spin_unlock_irqrestore(&ams->intr_lock, flags);  } @@ -1035,28 +1059,9 @@ static void ams_handle_events(struct iio_dev *indio_dev, unsigned long events)  static void ams_unmask_worker(struct work_struct *work)  {  	struct ams *ams = container_of(work, struct ams, ams_unmask_work.work); -	unsigned int status, unmask;  	spin_lock_irq(&ams->intr_lock); - -	status = readl(ams->base + AMS_ISR_0); - -	/* Clear those bits which are not active anymore */ -	unmask = (ams->current_masked_alarm ^ status) & ams->current_masked_alarm; - -	/* Clear status of disabled alarm */ -	unmask |= ams->intr_mask; - -	ams->current_masked_alarm &= status; - -	/* Also clear those which are masked out anyway */ -	ams->current_masked_alarm &= ~ams->intr_mask; - -	/* Clear the interrupts before we unmask them */ -	writel(unmask, ams->base + AMS_ISR_0); - -	ams_update_intrmask(ams, ~AMS_ALARM_MASK, ~AMS_ALARM_MASK); - +	ams_unmask(ams);  	spin_unlock_irq(&ams->intr_lock);  	/* If still pending some alarm re-trigger the timer */ | 
