提交 635d19be 编写于 作者: D Dominik Brodowski

pcmcia: deprecate CS_NO_MORE_ITEMS

CS_NO_MORE_ITEMS is returned by the CIS tuple reading and parsing code if
the end of a tuple chain is reached. As at least one PCMCIA driver relies
on matching this return value, replace it with -ENOSPC which is now
uniquely used for this purpose within the in-kernel pcmcia subsystem.

CC: Russell King <rmk+kernel@arm.linux.org.uk>
CC: linux-serial@vger.kernel.org
CC: Michael Buesch <mb@bu3sch.de>
Signed-off-by: NDominik Brodowski <linux@dominikbrodowski.net>
上级 f958095e
...@@ -450,7 +450,7 @@ int pccard_get_first_tuple(struct pcmcia_socket *s, unsigned int function, tuple ...@@ -450,7 +450,7 @@ int pccard_get_first_tuple(struct pcmcia_socket *s, unsigned int function, tuple
if (pccard_get_next_tuple(s, function, tuple) == 0) { if (pccard_get_next_tuple(s, function, tuple) == 0) {
tuple->DesiredTuple = CISTPL_LINKTARGET; tuple->DesiredTuple = CISTPL_LINKTARGET;
if (pccard_get_next_tuple(s, function, tuple) != 0) if (pccard_get_next_tuple(s, function, tuple) != 0)
return CS_NO_MORE_ITEMS; return -ENOSPC;
} else } else
tuple->CISOffset = tuple->TupleLink = 0; tuple->CISOffset = tuple->TupleLink = 0;
tuple->DesiredTuple = req; tuple->DesiredTuple = req;
...@@ -526,7 +526,7 @@ int pccard_get_next_tuple(struct pcmcia_socket *s, unsigned int function, tuple_ ...@@ -526,7 +526,7 @@ int pccard_get_next_tuple(struct pcmcia_socket *s, unsigned int function, tuple_
/* End of chain? Follow long link if possible */ /* End of chain? Follow long link if possible */
if (link[0] == CISTPL_END) { if (link[0] == CISTPL_END) {
if ((ofs = follow_link(s, tuple)) < 0) if ((ofs = follow_link(s, tuple)) < 0)
return CS_NO_MORE_ITEMS; return -ENOSPC;
attr = SPACE(tuple->Flags); attr = SPACE(tuple->Flags);
read_cis_cache(s, attr, ofs, 2, link); read_cis_cache(s, attr, ofs, 2, link);
} }
...@@ -584,7 +584,7 @@ int pccard_get_next_tuple(struct pcmcia_socket *s, unsigned int function, tuple_ ...@@ -584,7 +584,7 @@ int pccard_get_next_tuple(struct pcmcia_socket *s, unsigned int function, tuple_
} }
if (i == MAX_TUPLES) { if (i == MAX_TUPLES) {
cs_dbg(s, 1, "cs: overrun in pcmcia_get_next_tuple\n"); cs_dbg(s, 1, "cs: overrun in pcmcia_get_next_tuple\n");
return CS_NO_MORE_ITEMS; return -ENOSPC;
} }
tuple->TupleCode = link[0]; tuple->TupleCode = link[0];
...@@ -606,7 +606,7 @@ int pccard_get_tuple_data(struct pcmcia_socket *s, tuple_t *tuple) ...@@ -606,7 +606,7 @@ int pccard_get_tuple_data(struct pcmcia_socket *s, tuple_t *tuple)
return -EINVAL; return -EINVAL;
if (tuple->TupleLink < tuple->TupleOffset) if (tuple->TupleLink < tuple->TupleOffset)
return CS_NO_MORE_ITEMS; return -ENOSPC;
len = tuple->TupleLink - tuple->TupleOffset; len = tuple->TupleLink - tuple->TupleOffset;
tuple->TupleDataLen = tuple->TupleLink; tuple->TupleDataLen = tuple->TupleLink;
if (len == 0) if (len == 0)
...@@ -1490,7 +1490,7 @@ int pccard_validate_cis(struct pcmcia_socket *s, unsigned int function, unsigned ...@@ -1490,7 +1490,7 @@ int pccard_validate_cis(struct pcmcia_socket *s, unsigned int function, unsigned
cards have only a broken VERS_2 tuple; hence the bogus test. */ cards have only a broken VERS_2 tuple; hence the bogus test. */
if ((pccard_read_tuple(s, function, CISTPL_MANFID, p) == 0) || if ((pccard_read_tuple(s, function, CISTPL_MANFID, p) == 0) ||
(pccard_read_tuple(s, function, CISTPL_VERS_1, p) == 0) || (pccard_read_tuple(s, function, CISTPL_VERS_1, p) == 0) ||
(pccard_read_tuple(s, function, CISTPL_VERS_2, p) != CS_NO_MORE_ITEMS)) (pccard_read_tuple(s, function, CISTPL_VERS_2, p) != -ENOSPC))
ident_ok++; ident_ok++;
if (!dev_ok && !ident_ok) if (!dev_ok && !ident_ok)
......
...@@ -88,7 +88,7 @@ static const lookup_t error_table[] = { ...@@ -88,7 +88,7 @@ static const lookup_t error_table[] = {
{ CS_BAD_ARGS, "Bad arguments" }, { CS_BAD_ARGS, "Bad arguments" },
{ -EACCES, "Configuration locked" }, { -EACCES, "Configuration locked" },
{ CS_IN_USE, "Resource in use" }, { CS_IN_USE, "Resource in use" },
{ CS_NO_MORE_ITEMS, "No more items" }, { -ENOSPC, "No more items" },
{ CS_OUT_OF_RESOURCE, "Out of resource" }, { CS_OUT_OF_RESOURCE, "Out of resource" },
{ CS_BAD_TUPLE, "Bad CIS tuple" } { CS_BAD_TUPLE, "Bad CIS tuple" }
}; };
......
...@@ -973,7 +973,7 @@ static int ds_ioctl(struct inode * inode, struct file * file, ...@@ -973,7 +973,7 @@ static int ds_ioctl(struct inode * inode, struct file * file,
err = -EBUSY; break; err = -EBUSY; break;
case CS_OUT_OF_RESOURCE: case CS_OUT_OF_RESOURCE:
err = -ENOSPC; break; err = -ENOSPC; break;
case CS_NO_MORE_ITEMS: case -ENOSPC:
err = -ENODATA; break; err = -ENODATA; break;
case -ENOSYS: case -ENOSYS:
err = -ENOSYS; break; err = -ENOSYS; break;
......
...@@ -211,7 +211,7 @@ int pcmcia_get_window(struct pcmcia_socket *s, window_handle_t *handle, ...@@ -211,7 +211,7 @@ int pcmcia_get_window(struct pcmcia_socket *s, window_handle_t *handle,
if (s->state & SOCKET_WIN_REQ(w)) if (s->state & SOCKET_WIN_REQ(w))
break; break;
if (w == MAX_WIN) if (w == MAX_WIN)
return CS_NO_MORE_ITEMS; return -EINVAL;
win = &s->win[w]; win = &s->win[w];
req->Base = win->ctl.res->start; req->Base = win->ctl.res->start;
req->Size = win->ctl.res->end - win->ctl.res->start + 1; req->Size = win->ctl.res->end - win->ctl.res->start + 1;
......
...@@ -432,7 +432,7 @@ first_tuple(struct pcmcia_device *handle, tuple_t * tuple, cisparse_t * parse) ...@@ -432,7 +432,7 @@ first_tuple(struct pcmcia_device *handle, tuple_t * tuple, cisparse_t * parse)
int i; int i;
i = pcmcia_get_first_tuple(handle, tuple); i = pcmcia_get_first_tuple(handle, tuple);
if (i != 0) if (i != 0)
return CS_NO_MORE_ITEMS; return i;
i = pcmcia_get_tuple_data(handle, tuple); i = pcmcia_get_tuple_data(handle, tuple);
if (i != 0) if (i != 0)
return i; return i;
......
...@@ -733,7 +733,7 @@ int ssb_pcmcia_get_invariants(struct ssb_bus *bus, ...@@ -733,7 +733,7 @@ int ssb_pcmcia_get_invariants(struct ssb_bus *bus,
break; break;
} }
res = pcmcia_get_next_tuple(bus->host_pcmcia, &tuple); res = pcmcia_get_next_tuple(bus->host_pcmcia, &tuple);
if (res == CS_NO_MORE_ITEMS) if (res == -ENOSPC)
break; break;
GOTO_ERROR_ON(res != 0, "VEN next tpl"); GOTO_ERROR_ON(res != 0, "VEN next tpl");
res = pcmcia_get_tuple_data(bus->host_pcmcia, &tuple); res = pcmcia_get_tuple_data(bus->host_pcmcia, &tuple);
......
...@@ -315,7 +315,7 @@ typedef struct error_info_t { ...@@ -315,7 +315,7 @@ typedef struct error_info_t {
#define CS_BAD_ARGS 0x1c #define CS_BAD_ARGS 0x1c
#define CS_CONFIGURATION_LOCKED -EACCES #define CS_CONFIGURATION_LOCKED -EACCES
#define CS_IN_USE -EBUSY #define CS_IN_USE -EBUSY
#define CS_NO_MORE_ITEMS 0x1f #define CS_NO_MORE_ITEMS -ENOSPC
#define CS_OUT_OF_RESOURCE -ENOMEM #define CS_OUT_OF_RESOURCE -ENOMEM
#define CS_BAD_HANDLE -EINVAL #define CS_BAD_HANDLE -EINVAL
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册