pcmcia: remove Pin, Copy configuration register access

The "Pin" and "Copy" configuration registers (CISREG_SCR, CISREG_PPR)
do not seem to be utilized anywhere. If a device would request a
write to these registers, "0" would be written. Continue to do so, but
warn of unexpected behavior -- and remove the "Pin" and "Copy" entries
from config_req_t.

Tested-by: Wolfram Sang <w.sang@pengutronix.de>
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
This commit is contained in:
Dominik Brodowski 2010-07-29 15:54:54 +02:00
parent e8405f0f61
commit 1a4a046030
3 changed files with 10 additions and 8 deletions

View file

@ -36,7 +36,7 @@ typedef struct config_t {
unsigned int Attributes; unsigned int Attributes;
unsigned int IntType; unsigned int IntType;
unsigned int ConfigBase; unsigned int ConfigBase;
unsigned char Status, Pin, Copy, Option, ExtStatus; unsigned char Status, Option, ExtStatus;
unsigned int CardValues; unsigned int CardValues;
struct resource io[MAX_IO_WIN]; /* io ports */ struct resource io[MAX_IO_WIN]; /* io ports */

View file

@ -489,8 +489,14 @@ int pcmcia_request_configuration(struct pcmcia_device *p_dev,
base = c->ConfigBase = req->ConfigBase; base = c->ConfigBase = req->ConfigBase;
c->CardValues = req->Present; c->CardValues = req->Present;
if (req->Present & PRESENT_COPY) { if (req->Present & PRESENT_COPY) {
c->Copy = req->Copy; u16 tmp = 0;
pcmcia_write_cis_mem(s, 1, (base + CISREG_SCR)>>1, 1, &c->Copy); dev_dbg(&p_dev->dev, "clearing CISREG_SCR\n");
pcmcia_write_cis_mem(s, 1, (base + CISREG_SCR)>>1, 1, &tmp);
}
if (req->Present & PRESENT_PIN_REPLACE) {
u16 tmp = 0;
dev_dbg(&p_dev->dev, "clearing CISREG_PRR\n");
pcmcia_write_cis_mem(s, 1, (base + CISREG_PRR)>>1, 1, &tmp);
} }
if (req->Present & PRESENT_OPTION) { if (req->Present & PRESENT_OPTION) {
if (s->functions == 1) { if (s->functions == 1) {
@ -511,10 +517,6 @@ int pcmcia_request_configuration(struct pcmcia_device *p_dev,
c->Status = req->Status; c->Status = req->Status;
pcmcia_write_cis_mem(s, 1, (base + CISREG_CCSR)>>1, 1, &c->Status); pcmcia_write_cis_mem(s, 1, (base + CISREG_CCSR)>>1, 1, &c->Status);
} }
if (req->Present & PRESENT_PIN_REPLACE) {
c->Pin = req->Pin;
pcmcia_write_cis_mem(s, 1, (base + CISREG_PRR)>>1, 1, &c->Pin);
}
if (req->Present & PRESENT_EXT_STATUS) { if (req->Present & PRESENT_EXT_STATUS) {
c->ExtStatus = req->ExtStatus; c->ExtStatus = req->ExtStatus;
pcmcia_write_cis_mem(s, 1, (base + CISREG_ESR)>>1, 1, &c->ExtStatus); pcmcia_write_cis_mem(s, 1, (base + CISREG_ESR)>>1, 1, &c->ExtStatus);

View file

@ -24,7 +24,7 @@ typedef struct config_req_t {
u_int Attributes; u_int Attributes;
u_int IntType; u_int IntType;
u_int ConfigBase; u_int ConfigBase;
u_char Status, Pin, Copy, ExtStatus; u_char Status, ExtStatus;
u_char ConfigIndex; u_char ConfigIndex;
u_int Present; u_int Present;
} config_req_t; } config_req_t;