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:
parent
e8405f0f61
commit
1a4a046030
3 changed files with 10 additions and 8 deletions
|
@ -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 */
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue