On Fri, Sep 02, 2016 at 10:55:19AM -0500, Bjorn Helgaas wrote:
> 
> ---
>  drivers/pci/host/pcie-rockchip.c |  148 
> +++++++++++++++++++-------------------
>  1 file changed, 74 insertions(+), 74 deletions(-)
> 
> diff --git a/drivers/pci/host/pcie-rockchip.c 
> b/drivers/pci/host/pcie-rockchip.c
> index 6edfce5..fe1b52f 100644
> --- a/drivers/pci/host/pcie-rockchip.c
> +++ b/drivers/pci/host/pcie-rockchip.c
> @@ -37,21 +37,27 @@
>  #include <linux/reset.h>
>  #include <linux/regmap.h>
>  
> -#define PCIE_CLIENT_BASE                     0x0
> -#define PCIE_RC_CONFIG_BASE                  0xa00000
> -#define PCIE_RC_CONFIG_L1_SUBSTATE_CTRL2     (PCIE_RC_CONFIG_BASE + 0x90c)
> -#define PCIE_RC_CONFIG_LCS                   (PCIE_RC_CONFIG_BASE + 0x0d0)
> -#define  PCIE_RC_CONFIG_LCS_RETRAIN_LINK     BIT(5)
> -#define  PCIE_RC_CONFIG_LCS_LBMIE            BIT(10)
> -#define  PCIE_RC_CONFIG_LCS_LABIE            BIT(11)
> -#define  PCIE_RC_CONFIG_LCS_LBMS             BIT(30)
> -#define  PCIE_RC_CONFIG_LCS_LAMS             BIT(31)
> -#define PCIE_CORE_CTRL_MGMT_BASE             0x900000
> -#define PCIE_CORE_AXI_CONF_BASE                      0xc00000
> -#define PCIE_CORE_AXI_INBOUND_BASE           0xc00800
> -#define PCIE_CLIENT_BASIC_STATUS1            (PCIE_CLIENT_BASE + 0x48)
> -#define PCIE_CLIENT_INT_MASK                 (PCIE_CLIENT_BASE + 0x4c)
> -#define PCIE_CLIENT_INT_STATUS                       (PCIE_CLIENT_BASE + 
> 0x50)
> +/*
> + * The upper 16 bits of PCIE_CLIENT_BASE are a write mask for the lower 16
> + * bits.  This allows atomic updates of the register without locking.
> + */
> +#define HIWORD_UPDATE(mask, val)     ((mask << 16) | val)
> +
(mask), (val)

> +#define ENCODE_LANES(x)                      (((x >> 1) & 3) << 4)

(x)

Guenter

Reply via email to