Re: [PATCH v7] SATA: OCTEON: support SATA on OCTEON platform

From: Zubair Lutfullah Kakakhel
Date: Thu Feb 04 2016 - 11:06:08 EST


Hi,

Thank-you for the review.

On 04/02/16 12:24, Aleksey Makarov wrote:

Hi Zubair,

+ void __iomem *base;

[..]

+ cfg = cvmx_read_csr((uint64_t)base + CVMX_SATA_UCTL_SHIM_CFG);

sparse will complain here. See Documentation/sparse.txt

Yes. sparse says

...
CHECK drivers/ata/sata_octeon.c
drivers/ata/sata_octeon.c:50:30: warning: cast removes address space of expression
drivers/ata/sata_octeon.c:65:25: warning: cast removes address space of expression
...

Use of (__force uint64_t) removes the sparse warning. But it was
frowned upon by arnd.

He suggested a wrapper helper in asm/octeon/cvmx.h which handles iomem
addresses and __force behind the scenes rather than in the driver.

static inline void cvmx_write_csr_resource(void __iomem *csr_addr, uint64_t val)
{
cvmx_write_csr((__force uint64_t)csr_addr, val)
}

Alternatives? Or should I resend with the above wrapper?

Regards,
ZubairLK


Thank you
Aleksey Makarov