Commit 01723a95 authored by Linus Walleij's avatar Linus Walleij Committed by Russell King

ARM: 6368/1: move the PrimeCell IDs to use macros

This make four macros for the PrimeCell ID register available to
drivers that use them witout using the PrimeCell/AMBA bus
abstraction and struct amba_device. It also moves the magic
PrimeCell CID "B105F00D" to the bus.h header file.
Signed-off-by: default avatarLinus Walleij <linus.walleij@stericsson.com>
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent 2da6d64a
...@@ -298,7 +298,7 @@ int amba_device_register(struct amba_device *dev, struct resource *parent) ...@@ -298,7 +298,7 @@ int amba_device_register(struct amba_device *dev, struct resource *parent)
amba_put_disable_pclk(dev); amba_put_disable_pclk(dev);
if (cid == 0xb105f00d) if (cid == AMBA_CID)
dev->periphid = pid; dev->periphid = pid;
if (!dev->periphid) if (!dev->periphid)
......
...@@ -20,6 +20,7 @@ ...@@ -20,6 +20,7 @@
#include <linux/resource.h> #include <linux/resource.h>
#define AMBA_NR_IRQS 2 #define AMBA_NR_IRQS 2
#define AMBA_CID 0xb105f00d
struct clk; struct clk;
...@@ -70,9 +71,15 @@ void amba_release_regions(struct amba_device *); ...@@ -70,9 +71,15 @@ void amba_release_regions(struct amba_device *);
#define amba_pclk_disable(d) \ #define amba_pclk_disable(d) \
do { if (!IS_ERR((d)->pclk)) clk_disable((d)->pclk); } while (0) do { if (!IS_ERR((d)->pclk)) clk_disable((d)->pclk); } while (0)
#define amba_config(d) (((d)->periphid >> 24) & 0xff) /* Some drivers don't use the struct amba_device */
#define amba_rev(d) (((d)->periphid >> 20) & 0x0f) #define AMBA_CONFIG_BITS(a) (((a) >> 24) & 0xff)
#define amba_manf(d) (((d)->periphid >> 12) & 0xff) #define AMBA_REV_BITS(a) (((a) >> 20) & 0x0f)
#define amba_part(d) ((d)->periphid & 0xfff) #define AMBA_MANF_BITS(a) (((a) >> 12) & 0xff)
#define AMBA_PART_BITS(a) ((a) & 0xfff)
#define amba_config(d) AMBA_CONFIG_BITS((d)->periphid)
#define amba_rev(d) AMBA_REV_BITS((d)->periphid)
#define amba_manf(d) AMBA_MANF_BITS((d)->periphid)
#define amba_part(d) AMBA_PART_BITS((d)->periphid)
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment