The devicetree data structures have been available in more than just ramstage and romstage. In order to provide clearer and consistent semantics two new macros are provided: 1. DEVTREE_EARLY which is true when !ENV_RAMSTAGE 2. DEVTREE_CONST as a replacment for ROMSTAGE_CONST The ROMSTAGE_CONST attribute is used in the source code to mark the devicetree data structures as const in early stages even though it's not just romstage. Therefore, rename the attribute to DEVTREE_CONST as that's the actual usage. The only place where the usage was not devicetree related is console_loglevel, but the same name was used for consistency. Any stage that is not ramstage has the const C attribute applied when DEVTREE_CONST is used. Change-Id: Ibd51c2628dc8f68e0896974f7e4e7c8588d333ed Signed-off-by: Aaron Durbin <adurbin@chromium.org> Reviewed-on: https://review.coreboot.org/19333 Tested-by: build bot (Jenkins) Reviewed-by: Philippe Mathieu-Daudé <philippe.mathieu.daude@gmail.com> Reviewed-by: Furquan Shaikh <furquan@google.com>
92 lines
3.5 KiB
C
92 lines
3.5 KiB
C
#ifndef DEVICE_RESOURCE_H
|
|
#define DEVICE_RESOURCE_H
|
|
|
|
#include <stdint.h>
|
|
#include <stddef.h>
|
|
|
|
#define IORESOURCE_BITS 0x000000ff /* Bus-specific bits */
|
|
|
|
#define IORESOURCE_IO 0x00000100 /* Resource type */
|
|
#define IORESOURCE_MEM 0x00000200
|
|
#define IORESOURCE_IRQ 0x00000400
|
|
#define IORESOURCE_DRQ 0x00000800
|
|
|
|
#define IORESOURCE_TYPE_MASK (IORESOURCE_IO | IORESOURCE_MEM \
|
|
| IORESOURCE_IRQ | IORESOURCE_DRQ)
|
|
|
|
#define IORESOURCE_PREFETCH 0x00001000 /* No side effects */
|
|
#define IORESOURCE_READONLY 0x00002000
|
|
#define IORESOURCE_CACHEABLE 0x00004000
|
|
#define IORESOURCE_RANGELENGTH 0x00008000
|
|
#define IORESOURCE_SHADOWABLE 0x00010000
|
|
#define IORESOURCE_BUS_HAS_VGA 0x00020000
|
|
/* This resource filters all of the unclaimed transactions to the bus below. */
|
|
#define IORESOURCE_SUBTRACTIVE 0x00040000
|
|
/* The IO resource has a bus below it. */
|
|
#define IORESOURCE_BRIDGE 0x00080000
|
|
/* The resource needs to be reserved in the coreboot table */
|
|
#define IORESOURCE_RESERVE 0x10000000
|
|
/* The IO resource assignment has been stored in the device */
|
|
#define IORESOURCE_STORED 0x20000000
|
|
/* An IO resource that has been assigned a value */
|
|
#define IORESOURCE_ASSIGNED 0x40000000
|
|
/* An IO resource the allocator must not change */
|
|
#define IORESOURCE_FIXED 0x80000000
|
|
|
|
/* PCI specific resource bits (IORESOURCE_BITS) */
|
|
#define IORESOURCE_PCI64 (1<<0) /* 64bit long pci resource */
|
|
#define IORESOURCE_PCI_BRIDGE (1<<1) /* A bridge pci resource */
|
|
|
|
typedef u64 resource_t;
|
|
struct resource {
|
|
resource_t base; /* Base address of the resource */
|
|
resource_t size; /* Size of the resource */
|
|
resource_t limit; /* Largest valid value base + size -1 */
|
|
DEVTREE_CONST struct resource *next; /* Next resource in the list */
|
|
unsigned long flags; /* Descriptions of the kind of resource */
|
|
unsigned long index; /* Bus specific per device resource id */
|
|
unsigned char align; /* Required alignment (log 2) of the resource */
|
|
unsigned char gran; /* Granularity (log 2) of the resource */
|
|
/* Alignment must be >= the granularity of the resource */
|
|
};
|
|
|
|
/* Macros to generate index values for resources */
|
|
#define IOINDEX_SUBTRACTIVE(IDX, LINK) (0x10000000 + ((IDX) << 8) + LINK)
|
|
#define IOINDEX_SUBTRACTIVE_LINK(IDX) (IDX & 0xff)
|
|
|
|
#define IOINDEX(IDX, LINK) (((LINK) << 16) + IDX)
|
|
#define IOINDEX_LINK(IDX) ((IDX & 0xf0000) >> 16)
|
|
#define IOINDEX_IDX(IDX) (IDX & 0xffff)
|
|
|
|
/* Generic resource helper functions */
|
|
struct device;
|
|
struct bus;
|
|
extern void compact_resources(struct device *dev);
|
|
extern struct resource *probe_resource(struct device *dev, unsigned int index);
|
|
extern struct resource *new_resource(struct device *dev, unsigned int index);
|
|
extern struct resource *find_resource(struct device *dev, unsigned int index);
|
|
extern resource_t resource_end(struct resource *resource);
|
|
extern resource_t resource_max(struct resource *resource);
|
|
extern void report_resource_stored(struct device *dev,
|
|
struct resource *resource, const char *comment);
|
|
|
|
typedef void (*resource_search_t)(void *gp, struct device *dev,
|
|
struct resource *res);
|
|
extern void search_bus_resources(struct bus *bus,
|
|
unsigned long type_mask, unsigned long type,
|
|
resource_search_t search, void *gp);
|
|
|
|
extern void search_global_resources(
|
|
unsigned long type_mask, unsigned long type,
|
|
resource_search_t search, void *gp);
|
|
|
|
#define RESOURCE_TYPE_MAX 20
|
|
extern const char *resource_type(struct resource *resource);
|
|
|
|
static inline void *res2mmio(struct resource *res, unsigned long offset,
|
|
unsigned long mask)
|
|
{
|
|
return (void *)(uintptr_t)((res->base + offset) & ~mask);
|
|
}
|
|
|
|
#endif /* DEVICE_RESOURCE_H */
|