[PATCH v2] ath10k: Replace ioread with mb to drain write buffer

Peter Oh poh at qca.qualcomm.com
Fri Jan 30 16:22:21 PST 2015


On 01/30/2015 04:14 PM, Peter Oh wrote:
> Using ioread() to perform draining write buffer is excessive.
> Use compact API, mb(), that intended to be used for the case.
> It reduces total 14 CPU clocks per interrupt.
>
> Signed-off-by: Peter Oh <poh at qca.qualcomm.com>
> ---
>   drivers/net/wireless/ath/ath10k/pci.c | 12 ++++--------
>   1 file changed, 4 insertions(+), 8 deletions(-)
>
> diff --git a/drivers/net/wireless/ath/ath10k/pci.c b/drivers/net/wireless/ath/ath10k/pci.c
> index e6972b0..f1e6980 100644
> --- a/drivers/net/wireless/ath/ath10k/pci.c
> +++ b/drivers/net/wireless/ath/ath10k/pci.c
> @@ -353,10 +353,8 @@ static void ath10k_pci_disable_and_clear_legacy_irq(struct ath10k *ar)
>   	ath10k_pci_write32(ar, SOC_CORE_BASE_ADDRESS + PCIE_INTR_CLR_ADDRESS,
>   			   PCIE_INTR_FIRMWARE_MASK | PCIE_INTR_CE_MASK_ALL);
>   
> -	/* IMPORTANT: this extra read transaction is required to
> -	 * flush the posted write buffer. */
> -	(void)ath10k_pci_read32(ar, SOC_CORE_BASE_ADDRESS +
> -				PCIE_INTR_ENABLE_ADDRESS);
> +	/* drain write buffer */
> +	mb();
It figured out that ath10k_pci_read32() use dsb with 'st' while wmb() is 
use with 'sy'.
So updated it from wmb() to mb() for the same effect as ath10k_pci_read32().
>   }
>   
>   static void ath10k_pci_enable_legacy_irq(struct ath10k *ar)
> @@ -365,10 +363,8 @@ static void ath10k_pci_enable_legacy_irq(struct ath10k *ar)
>   			   PCIE_INTR_ENABLE_ADDRESS,
>   			   PCIE_INTR_FIRMWARE_MASK | PCIE_INTR_CE_MASK_ALL);
>   
> -	/* IMPORTANT: this extra read transaction is required to
> -	 * flush the posted write buffer. */
> -	(void)ath10k_pci_read32(ar, SOC_CORE_BASE_ADDRESS +
> -				PCIE_INTR_ENABLE_ADDRESS);
> +	/* drain write buffer */
> +	mb();
>   }
>   
>   static inline const char *ath10k_pci_get_irq_method(struct ath10k *ar)
Thanks,
Peter



More information about the ath10k mailing list