mei: use non cached hcsr for interrupt enablement
authorTomas Winkler <tomas.winkler@intel.com>
Tue, 8 Jan 2013 21:07:28 +0000 (23:07 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 9 Jan 2013 00:40:47 +0000 (16:40 -0800)
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/misc/mei/hw-me.c
drivers/misc/mei/interrupt.c
drivers/misc/mei/main.c

index ec4ab895f03d1022b3794f26a8cc5f9676a9826e..ed61659fd388f387a80ebc7e6a080d5e208e97bd 100644 (file)
@@ -106,8 +106,9 @@ void mei_hcsr_set(struct mei_device *dev)
  */
 void mei_clear_interrupts(struct mei_device *dev)
 {
-       if ((dev->host_hw_state & H_IS) == H_IS)
-               mei_reg_write(dev, H_CSR, dev->host_hw_state);
+       u32 hcsr = mei_hcsr_read(dev);
+       if ((hcsr & H_IS) == H_IS)
+               mei_reg_write(dev, H_CSR, hcsr);
 }
 
 /**
@@ -117,8 +118,10 @@ void mei_clear_interrupts(struct mei_device *dev)
  */
 void mei_enable_interrupts(struct mei_device *dev)
 {
-       dev->host_hw_state |= H_IE;
-       mei_hcsr_set(dev);
+       u32 hcsr = mei_hcsr_read(dev);
+       hcsr |= H_IE;
+       hcsr &= ~H_IS;
+       mei_reg_write(dev, H_CSR, hcsr);
 }
 
 /**
@@ -128,8 +131,10 @@ void mei_enable_interrupts(struct mei_device *dev)
  */
 void mei_disable_interrupts(struct mei_device *dev)
 {
-       dev->host_hw_state &= ~H_IE;
-       mei_hcsr_set(dev);
+       u32 hcsr = mei_hcsr_read(dev);
+       hcsr  &= ~H_IE;
+       hcsr &= ~H_IS;
+       mei_reg_write(dev, H_CSR, hcsr);
 }
 
 /**
index d1ef92617c19d860a38e02fc073b52fcb28f45e5..d7e1b797e87b388a4461ef2d5bce70783ee5c038 100644 (file)
@@ -691,7 +691,6 @@ irqreturn_t mei_interrupt_thread_handler(int irq, void *dev_id)
        /* initialize our complete list */
        mutex_lock(&dev->device_lock);
        mei_io_list_init(&complete_list);
-       dev->host_hw_state = mei_hcsr_read(dev);
 
        /* Ack the interrupt here
         * In case of MSI we don't go through the quick handler */
@@ -710,6 +709,7 @@ irqreturn_t mei_interrupt_thread_handler(int irq, void *dev_id)
                return IRQ_HANDLED;
        }
 
+       dev->host_hw_state = mei_hcsr_read(dev);
        /*  check if we need to start the dev */
        if ((dev->host_hw_state & H_RDY) == 0) {
                if ((dev->me_hw_state & ME_RDY_HRA) == ME_RDY_HRA) {
index ec5fd7a0e2894e1e1b22b2c03f777bbef496af93..f72bb77fc279a1c887d8ba430fb1554a6d88a96a 100644 (file)
@@ -915,8 +915,6 @@ static int mei_probe(struct pci_dev *pdev,
        return 0;
 
 release_irq:
-       /* disable interrupts */
-       dev->host_hw_state = mei_hcsr_read(dev);
        mei_disable_interrupts(dev);
        flush_scheduled_work();
        free_irq(pdev->irq, dev);