Commit 02d83b5d authored by Bjorn Helgaas's avatar Bjorn Helgaas Committed by Len Brown

PNP: make pnp_resource_table private to PNP core

There are no remaining references to the PNP_MAX_* constants or
the pnp_resource_table structure outside of the PNP core.  Make
them private to the PNP core.
Signed-off-by: default avatarBjorn Helgaas <bjorn.helgaas@hp.com>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent 8766ad0c
...@@ -20,3 +20,15 @@ int pnp_check_dma(struct pnp_dev *dev, struct resource *res); ...@@ -20,3 +20,15 @@ int pnp_check_dma(struct pnp_dev *dev, struct resource *res);
void dbg_pnp_show_resources(struct pnp_dev *dev, char *desc); void dbg_pnp_show_resources(struct pnp_dev *dev, char *desc);
void pnp_init_resource(struct resource *res); void pnp_init_resource(struct resource *res);
#define PNP_MAX_PORT 40
#define PNP_MAX_MEM 24
#define PNP_MAX_IRQ 2
#define PNP_MAX_DMA 2
struct pnp_resource_table {
struct resource port_resource[PNP_MAX_PORT];
struct resource mem_resource[PNP_MAX_MEM];
struct resource dma_resource[PNP_MAX_DMA];
struct resource irq_resource[PNP_MAX_IRQ];
};
...@@ -106,6 +106,7 @@ static void pnp_release_device(struct device *dmdev) ...@@ -106,6 +106,7 @@ static void pnp_release_device(struct device *dmdev)
pnp_free_option(dev->independent); pnp_free_option(dev->independent);
pnp_free_option(dev->dependent); pnp_free_option(dev->dependent);
pnp_free_ids(dev); pnp_free_ids(dev);
kfree(dev->res);
kfree(dev); kfree(dev);
} }
...@@ -118,6 +119,12 @@ struct pnp_dev *pnp_alloc_dev(struct pnp_protocol *protocol, int id, char *pnpid ...@@ -118,6 +119,12 @@ struct pnp_dev *pnp_alloc_dev(struct pnp_protocol *protocol, int id, char *pnpid
if (!dev) if (!dev)
return NULL; return NULL;
dev->res = kzalloc(sizeof(struct pnp_resource_table), GFP_KERNEL);
if (!dev->res) {
kfree(dev);
return NULL;
}
dev->protocol = protocol; dev->protocol = protocol;
dev->number = id; dev->number = id;
dev->dma_mask = DMA_24BIT_MASK; dev->dma_mask = DMA_24BIT_MASK;
...@@ -133,6 +140,7 @@ struct pnp_dev *pnp_alloc_dev(struct pnp_protocol *protocol, int id, char *pnpid ...@@ -133,6 +140,7 @@ struct pnp_dev *pnp_alloc_dev(struct pnp_protocol *protocol, int id, char *pnpid
dev_id = pnp_add_id(dev, pnpid); dev_id = pnp_add_id(dev, pnpid);
if (!dev_id) { if (!dev_id) {
kfree(dev->res);
kfree(dev); kfree(dev);
return NULL; return NULL;
} }
......
...@@ -931,7 +931,7 @@ EXPORT_SYMBOL(isapnp_write_byte); ...@@ -931,7 +931,7 @@ EXPORT_SYMBOL(isapnp_write_byte);
static int isapnp_read_resources(struct pnp_dev *dev) static int isapnp_read_resources(struct pnp_dev *dev)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int tmp, ret; int tmp, ret;
dev->active = isapnp_read_byte(ISAPNP_CFG_ACTIVATE); dev->active = isapnp_read_byte(ISAPNP_CFG_ACTIVATE);
...@@ -987,7 +987,7 @@ static int isapnp_get_resources(struct pnp_dev *dev) ...@@ -987,7 +987,7 @@ static int isapnp_get_resources(struct pnp_dev *dev)
static int isapnp_set_resources(struct pnp_dev *dev) static int isapnp_set_resources(struct pnp_dev *dev)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int tmp; int tmp;
dev_dbg(&dev->dev, "set resources\n"); dev_dbg(&dev->dev, "set resources\n");
......
...@@ -247,22 +247,22 @@ void pnp_init_resources(struct pnp_dev *dev) ...@@ -247,22 +247,22 @@ void pnp_init_resources(struct pnp_dev *dev)
int idx; int idx;
for (idx = 0; idx < PNP_MAX_IRQ; idx++) { for (idx = 0; idx < PNP_MAX_IRQ; idx++) {
res = &dev->res.irq_resource[idx]; res = &dev->res->irq_resource[idx];
res->flags = IORESOURCE_IRQ; res->flags = IORESOURCE_IRQ;
pnp_init_resource(res); pnp_init_resource(res);
} }
for (idx = 0; idx < PNP_MAX_DMA; idx++) { for (idx = 0; idx < PNP_MAX_DMA; idx++) {
res = &dev->res.dma_resource[idx]; res = &dev->res->dma_resource[idx];
res->flags = IORESOURCE_DMA; res->flags = IORESOURCE_DMA;
pnp_init_resource(res); pnp_init_resource(res);
} }
for (idx = 0; idx < PNP_MAX_PORT; idx++) { for (idx = 0; idx < PNP_MAX_PORT; idx++) {
res = &dev->res.port_resource[idx]; res = &dev->res->port_resource[idx];
res->flags = IORESOURCE_IO; res->flags = IORESOURCE_IO;
pnp_init_resource(res); pnp_init_resource(res);
} }
for (idx = 0; idx < PNP_MAX_MEM; idx++) { for (idx = 0; idx < PNP_MAX_MEM; idx++) {
res = &dev->res.mem_resource[idx]; res = &dev->res->mem_resource[idx];
res->flags = IORESOURCE_MEM; res->flags = IORESOURCE_MEM;
pnp_init_resource(res); pnp_init_resource(res);
} }
...@@ -278,28 +278,28 @@ static void pnp_clean_resource_table(struct pnp_dev *dev) ...@@ -278,28 +278,28 @@ static void pnp_clean_resource_table(struct pnp_dev *dev)
int idx; int idx;
for (idx = 0; idx < PNP_MAX_IRQ; idx++) { for (idx = 0; idx < PNP_MAX_IRQ; idx++) {
res = &dev->res.irq_resource[idx]; res = &dev->res->irq_resource[idx];
if (res->flags & IORESOURCE_AUTO) { if (res->flags & IORESOURCE_AUTO) {
res->flags = IORESOURCE_IRQ; res->flags = IORESOURCE_IRQ;
pnp_init_resource(res); pnp_init_resource(res);
} }
} }
for (idx = 0; idx < PNP_MAX_DMA; idx++) { for (idx = 0; idx < PNP_MAX_DMA; idx++) {
res = &dev->res.dma_resource[idx]; res = &dev->res->dma_resource[idx];
if (res->flags & IORESOURCE_AUTO) { if (res->flags & IORESOURCE_AUTO) {
res->flags = IORESOURCE_DMA; res->flags = IORESOURCE_DMA;
pnp_init_resource(res); pnp_init_resource(res);
} }
} }
for (idx = 0; idx < PNP_MAX_PORT; idx++) { for (idx = 0; idx < PNP_MAX_PORT; idx++) {
res = &dev->res.port_resource[idx]; res = &dev->res->port_resource[idx];
if (res->flags & IORESOURCE_AUTO) { if (res->flags & IORESOURCE_AUTO) {
res->flags = IORESOURCE_IO; res->flags = IORESOURCE_IO;
pnp_init_resource(res); pnp_init_resource(res);
} }
} }
for (idx = 0; idx < PNP_MAX_MEM; idx++) { for (idx = 0; idx < PNP_MAX_MEM; idx++) {
res = &dev->res.mem_resource[idx]; res = &dev->res->mem_resource[idx];
if (res->flags & IORESOURCE_AUTO) { if (res->flags & IORESOURCE_AUTO) {
res->flags = IORESOURCE_MEM; res->flags = IORESOURCE_MEM;
pnp_init_resource(res); pnp_init_resource(res);
......
...@@ -21,6 +21,8 @@ ...@@ -21,6 +21,8 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/acpi.h> #include <linux/acpi.h>
#include <linux/pci.h> #include <linux/pci.h>
#include <linux/pnp.h>
#include "../base.h"
#include "pnpacpi.h" #include "pnpacpi.h"
#ifdef CONFIG_IA64 #ifdef CONFIG_IA64
...@@ -80,7 +82,7 @@ static void pnpacpi_parse_allocated_irqresource(struct pnp_dev *dev, ...@@ -80,7 +82,7 @@ static void pnpacpi_parse_allocated_irqresource(struct pnp_dev *dev,
u32 gsi, int triggering, u32 gsi, int triggering,
int polarity, int shareable) int polarity, int shareable)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int i = 0; int i = 0;
int irq; int irq;
int p, t; int p, t;
...@@ -176,7 +178,7 @@ static int dma_flags(int type, int bus_master, int transfer) ...@@ -176,7 +178,7 @@ static int dma_flags(int type, int bus_master, int transfer)
static void pnpacpi_parse_allocated_dmaresource(struct pnp_dev *dev, static void pnpacpi_parse_allocated_dmaresource(struct pnp_dev *dev,
u32 dma, int flags) u32 dma, int flags)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int i = 0; int i = 0;
static unsigned char warned; static unsigned char warned;
...@@ -202,7 +204,7 @@ static void pnpacpi_parse_allocated_dmaresource(struct pnp_dev *dev, ...@@ -202,7 +204,7 @@ static void pnpacpi_parse_allocated_dmaresource(struct pnp_dev *dev,
static void pnpacpi_parse_allocated_ioresource(struct pnp_dev *dev, static void pnpacpi_parse_allocated_ioresource(struct pnp_dev *dev,
u64 io, u64 len, int io_decode) u64 io, u64 len, int io_decode)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int i = 0; int i = 0;
static unsigned char warned; static unsigned char warned;
...@@ -230,7 +232,7 @@ static void pnpacpi_parse_allocated_memresource(struct pnp_dev *dev, ...@@ -230,7 +232,7 @@ static void pnpacpi_parse_allocated_memresource(struct pnp_dev *dev,
u64 mem, u64 len, u64 mem, u64 len,
int write_protect) int write_protect)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int i = 0; int i = 0;
static unsigned char warned; static unsigned char warned;
......
...@@ -56,7 +56,7 @@ inline void pcibios_penalize_isa_irq(int irq, int active) ...@@ -56,7 +56,7 @@ inline void pcibios_penalize_isa_irq(int irq, int active)
static void pnpbios_parse_allocated_irqresource(struct pnp_dev *dev, int irq) static void pnpbios_parse_allocated_irqresource(struct pnp_dev *dev, int irq)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int i = 0; int i = 0;
while (!(res->irq_resource[i].flags & IORESOURCE_UNSET) while (!(res->irq_resource[i].flags & IORESOURCE_UNSET)
...@@ -76,7 +76,7 @@ static void pnpbios_parse_allocated_irqresource(struct pnp_dev *dev, int irq) ...@@ -76,7 +76,7 @@ static void pnpbios_parse_allocated_irqresource(struct pnp_dev *dev, int irq)
static void pnpbios_parse_allocated_dmaresource(struct pnp_dev *dev, int dma) static void pnpbios_parse_allocated_dmaresource(struct pnp_dev *dev, int dma)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int i = 0; int i = 0;
while (i < PNP_MAX_DMA && while (i < PNP_MAX_DMA &&
...@@ -96,7 +96,7 @@ static void pnpbios_parse_allocated_dmaresource(struct pnp_dev *dev, int dma) ...@@ -96,7 +96,7 @@ static void pnpbios_parse_allocated_dmaresource(struct pnp_dev *dev, int dma)
static void pnpbios_parse_allocated_ioresource(struct pnp_dev *dev, static void pnpbios_parse_allocated_ioresource(struct pnp_dev *dev,
int io, int len) int io, int len)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int i = 0; int i = 0;
while (!(res->port_resource[i].flags & IORESOURCE_UNSET) while (!(res->port_resource[i].flags & IORESOURCE_UNSET)
...@@ -116,7 +116,7 @@ static void pnpbios_parse_allocated_ioresource(struct pnp_dev *dev, ...@@ -116,7 +116,7 @@ static void pnpbios_parse_allocated_ioresource(struct pnp_dev *dev,
static void pnpbios_parse_allocated_memresource(struct pnp_dev *dev, static void pnpbios_parse_allocated_memresource(struct pnp_dev *dev,
int mem, int len) int mem, int len)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
int i = 0; int i = 0;
while (!(res->mem_resource[i].flags & IORESOURCE_UNSET) while (!(res->mem_resource[i].flags & IORESOURCE_UNSET)
......
...@@ -502,7 +502,7 @@ int pnp_check_dma(struct pnp_dev *dev, struct resource *res) ...@@ -502,7 +502,7 @@ int pnp_check_dma(struct pnp_dev *dev, struct resource *res)
struct resource *pnp_get_resource(struct pnp_dev *dev, struct resource *pnp_get_resource(struct pnp_dev *dev,
unsigned int type, unsigned int num) unsigned int type, unsigned int num)
{ {
struct pnp_resource_table *res = &dev->res; struct pnp_resource_table *res = dev->res;
switch (type) { switch (type) {
case IORESOURCE_IO: case IORESOURCE_IO:
......
...@@ -13,14 +13,11 @@ ...@@ -13,14 +13,11 @@
#include <linux/errno.h> #include <linux/errno.h>
#include <linux/mod_devicetable.h> #include <linux/mod_devicetable.h>
#define PNP_MAX_PORT 40
#define PNP_MAX_MEM 24
#define PNP_MAX_IRQ 2
#define PNP_MAX_DMA 2
#define PNP_NAME_LEN 50 #define PNP_NAME_LEN 50
struct pnp_protocol; struct pnp_protocol;
struct pnp_dev; struct pnp_dev;
struct pnp_resource_table;
/* /*
* Resource Management * Resource Management
...@@ -184,13 +181,6 @@ struct pnp_option { ...@@ -184,13 +181,6 @@ struct pnp_option {
struct pnp_option *next; /* used to chain dependent resources */ struct pnp_option *next; /* used to chain dependent resources */
}; };
struct pnp_resource_table {
struct resource port_resource[PNP_MAX_PORT];
struct resource mem_resource[PNP_MAX_MEM];
struct resource dma_resource[PNP_MAX_DMA];
struct resource irq_resource[PNP_MAX_IRQ];
};
/* /*
* Device Management * Device Management
*/ */
...@@ -260,7 +250,7 @@ struct pnp_dev { ...@@ -260,7 +250,7 @@ struct pnp_dev {
int capabilities; int capabilities;
struct pnp_option *independent; struct pnp_option *independent;
struct pnp_option *dependent; struct pnp_option *dependent;
struct pnp_resource_table res; struct pnp_resource_table *res;
char name[PNP_NAME_LEN]; /* contains a human-readable name */ char name[PNP_NAME_LEN]; /* contains a human-readable name */
unsigned short regs; /* ISAPnP: supported registers */ unsigned short regs; /* ISAPnP: supported registers */
......
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