diff options
Diffstat (limited to 'drivers/pcmcia/cistpl.c')
-rw-r--r-- | drivers/pcmcia/cistpl.c | 43 |
1 files changed, 27 insertions, 16 deletions
diff --git a/drivers/pcmcia/cistpl.c b/drivers/pcmcia/cistpl.c index 1a513d9a8612..8d37768d0b46 100644 --- a/drivers/pcmcia/cistpl.c +++ b/drivers/pcmcia/cistpl.c | |||
@@ -352,7 +352,9 @@ int verify_cis_cache(struct pcmcia_socket *s) | |||
352 | 352 | ||
353 | buf = kmalloc(256, GFP_KERNEL); | 353 | buf = kmalloc(256, GFP_KERNEL); |
354 | if (buf == NULL) | 354 | if (buf == NULL) |
355 | return -1; | 355 | dev_printk(KERN_WARNING, &s->dev, |
356 | "no memory for verifying CIS\n"); | ||
357 | return -ENOMEM; | ||
356 | list_for_each_entry(cis, &s->cis_cache, node) { | 358 | list_for_each_entry(cis, &s->cis_cache, node) { |
357 | int len = cis->len; | 359 | int len = cis->len; |
358 | 360 | ||
@@ -384,15 +386,19 @@ int verify_cis_cache(struct pcmcia_socket *s) | |||
384 | int pcmcia_replace_cis(struct pcmcia_socket *s, | 386 | int pcmcia_replace_cis(struct pcmcia_socket *s, |
385 | const u8 *data, const size_t len) | 387 | const u8 *data, const size_t len) |
386 | { | 388 | { |
387 | if (len > CISTPL_MAX_CIS_SIZE) | 389 | if (len > CISTPL_MAX_CIS_SIZE) { |
388 | return CS_BAD_SIZE; | 390 | dev_printk(KERN_WARNING, &s->dev, "replacement CIS too big\n"); |
389 | kfree(s->fake_cis); | 391 | return -EINVAL; |
390 | s->fake_cis = kmalloc(len, GFP_KERNEL); | 392 | } |
391 | if (s->fake_cis == NULL) | 393 | kfree(s->fake_cis); |
392 | return CS_OUT_OF_RESOURCE; | 394 | s->fake_cis = kmalloc(len, GFP_KERNEL); |
393 | s->fake_cis_len = len; | 395 | if (s->fake_cis == NULL) { |
394 | memcpy(s->fake_cis, data, len); | 396 | dev_printk(KERN_WARNING, &s->dev, "no memory to replace CIS\n"); |
395 | return 0; | 397 | return -ENOMEM; |
398 | } | ||
399 | s->fake_cis_len = len; | ||
400 | memcpy(s->fake_cis, data, len); | ||
401 | return 0; | ||
396 | } | 402 | } |
397 | EXPORT_SYMBOL(pcmcia_replace_cis); | 403 | EXPORT_SYMBOL(pcmcia_replace_cis); |
398 | 404 | ||
@@ -1411,8 +1417,10 @@ int pccard_read_tuple(struct pcmcia_socket *s, unsigned int function, cisdata_t | |||
1411 | int ret; | 1417 | int ret; |
1412 | 1418 | ||
1413 | buf = kmalloc(256, GFP_KERNEL); | 1419 | buf = kmalloc(256, GFP_KERNEL); |
1414 | if (buf == NULL) | 1420 | if (buf == NULL) { |
1415 | return CS_OUT_OF_RESOURCE; | 1421 | dev_printk(KERN_WARNING, &s->dev, "no memory to read tuple\n"); |
1422 | return -ENOMEM; | ||
1423 | } | ||
1416 | tuple.DesiredTuple = code; | 1424 | tuple.DesiredTuple = code; |
1417 | tuple.Attributes = TUPLE_RETURN_COMMON; | 1425 | tuple.Attributes = TUPLE_RETURN_COMMON; |
1418 | ret = pccard_get_first_tuple(s, function, &tuple); | 1426 | ret = pccard_get_first_tuple(s, function, &tuple); |
@@ -1452,12 +1460,15 @@ int pccard_validate_cis(struct pcmcia_socket *s, unsigned int function, unsigned | |||
1452 | return CS_BAD_HANDLE; | 1460 | return CS_BAD_HANDLE; |
1453 | 1461 | ||
1454 | tuple = kmalloc(sizeof(*tuple), GFP_KERNEL); | 1462 | tuple = kmalloc(sizeof(*tuple), GFP_KERNEL); |
1455 | if (tuple == NULL) | 1463 | if (tuple == NULL) { |
1456 | return CS_OUT_OF_RESOURCE; | 1464 | dev_printk(KERN_WARNING, &s->dev, "no memory to validate CIS\n"); |
1465 | return -ENOMEM; | ||
1466 | } | ||
1457 | p = kmalloc(sizeof(*p), GFP_KERNEL); | 1467 | p = kmalloc(sizeof(*p), GFP_KERNEL); |
1458 | if (p == NULL) { | 1468 | if (p == NULL) { |
1459 | kfree(tuple); | 1469 | kfree(tuple); |
1460 | return CS_OUT_OF_RESOURCE; | 1470 | dev_printk(KERN_WARNING, &s->dev, "no memory to validate CIS\n"); |
1471 | return -ENOMEM; | ||
1461 | } | 1472 | } |
1462 | 1473 | ||
1463 | count = reserved = 0; | 1474 | count = reserved = 0; |