aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pcmcia/pcmcia_resource.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/pcmcia/pcmcia_resource.c')
-rw-r--r--drivers/pcmcia/pcmcia_resource.c63
1 files changed, 24 insertions, 39 deletions
diff --git a/drivers/pcmcia/pcmcia_resource.c b/drivers/pcmcia/pcmcia_resource.c
index 0bfb05aa8f85..349bc5662fff 100644
--- a/drivers/pcmcia/pcmcia_resource.c
+++ b/drivers/pcmcia/pcmcia_resource.c
@@ -44,21 +44,6 @@ static u8 pcmcia_used_irq[NR_IRQS];
44#endif 44#endif
45 45
46 46
47#ifdef CONFIG_PCMCIA_DEBUG
48extern int ds_pc_debug;
49
50#define ds_dbg(skt, lvl, fmt, arg...) do { \
51 if (ds_pc_debug >= lvl) \
52 dev_printk(KERN_DEBUG, &skt->dev, \
53 "pcmcia_resource: " fmt, \
54 ## arg); \
55} while (0)
56#else
57#define ds_dbg(skt, lvl, fmt, arg...) do { } while (0)
58#endif
59
60
61
62/** alloc_io_space 47/** alloc_io_space
63 * 48 *
64 * Special stuff for managing IO windows, because they are scarce 49 * Special stuff for managing IO windows, because they are scarce
@@ -73,14 +58,14 @@ static int alloc_io_space(struct pcmcia_socket *s, u_int attr,
73 align = (*base) ? (lines ? 1<<lines : 0) : 1; 58 align = (*base) ? (lines ? 1<<lines : 0) : 1;
74 if (align && (align < num)) { 59 if (align && (align < num)) {
75 if (*base) { 60 if (*base) {
76 ds_dbg(s, 0, "odd IO request: num %#x align %#x\n", 61 dev_dbg(&s->dev, "odd IO request: num %#x align %#x\n",
77 num, align); 62 num, align);
78 align = 0; 63 align = 0;
79 } else 64 } else
80 while (align && (align < num)) align <<= 1; 65 while (align && (align < num)) align <<= 1;
81 } 66 }
82 if (*base & ~(align-1)) { 67 if (*base & ~(align-1)) {
83 ds_dbg(s, 0, "odd IO request: base %#x align %#x\n", 68 dev_dbg(&s->dev, "odd IO request: base %#x align %#x\n",
84 *base, align); 69 *base, align);
85 align = 0; 70 align = 0;
86 } 71 }
@@ -253,12 +238,12 @@ int pcmcia_map_mem_page(window_handle_t win, memreq_t *req)
253 return -EINVAL; 238 return -EINVAL;
254 s = win->sock; 239 s = win->sock;
255 if (req->Page != 0) { 240 if (req->Page != 0) {
256 ds_dbg(s, 0, "failure: requested page is zero\n"); 241 dev_dbg(&s->dev, "failure: requested page is zero\n");
257 return -EINVAL; 242 return -EINVAL;
258 } 243 }
259 win->ctl.card_start = req->CardOffset; 244 win->ctl.card_start = req->CardOffset;
260 if (s->ops->set_mem_map(s, &win->ctl) != 0) { 245 if (s->ops->set_mem_map(s, &win->ctl) != 0) {
261 ds_dbg(s, 0, "failed to set_mem_map\n"); 246 dev_dbg(&s->dev, "failed to set_mem_map\n");
262 return -EIO; 247 return -EIO;
263 } 248 }
264 return 0; 249 return 0;
@@ -296,7 +281,7 @@ int pcmcia_modify_configuration(struct pcmcia_device *p_dev,
296 } 281 }
297 282
298 if (mod->Attributes & CONF_VCC_CHANGE_VALID) { 283 if (mod->Attributes & CONF_VCC_CHANGE_VALID) {
299 ds_dbg(s, 0, "changing Vcc is not allowed at this time\n"); 284 dev_dbg(&s->dev, "changing Vcc is not allowed at this time\n");
300 return -EINVAL; 285 return -EINVAL;
301 } 286 }
302 287
@@ -304,7 +289,7 @@ int pcmcia_modify_configuration(struct pcmcia_device *p_dev,
304 if ((mod->Attributes & CONF_VPP1_CHANGE_VALID) && 289 if ((mod->Attributes & CONF_VPP1_CHANGE_VALID) &&
305 (mod->Attributes & CONF_VPP2_CHANGE_VALID)) { 290 (mod->Attributes & CONF_VPP2_CHANGE_VALID)) {
306 if (mod->Vpp1 != mod->Vpp2) { 291 if (mod->Vpp1 != mod->Vpp2) {
307 ds_dbg(s, 0, "Vpp1 and Vpp2 must be the same\n"); 292 dev_dbg(&s->dev, "Vpp1 and Vpp2 must be the same\n");
308 return -EINVAL; 293 return -EINVAL;
309 } 294 }
310 s->socket.Vpp = mod->Vpp1; 295 s->socket.Vpp = mod->Vpp1;
@@ -315,7 +300,7 @@ int pcmcia_modify_configuration(struct pcmcia_device *p_dev,
315 } 300 }
316 } else if ((mod->Attributes & CONF_VPP1_CHANGE_VALID) || 301 } else if ((mod->Attributes & CONF_VPP1_CHANGE_VALID) ||
317 (mod->Attributes & CONF_VPP2_CHANGE_VALID)) { 302 (mod->Attributes & CONF_VPP2_CHANGE_VALID)) {
318 ds_dbg(s, 0, "changing Vcc is not allowed at this time\n"); 303 dev_dbg(&s->dev, "changing Vcc is not allowed at this time\n");
319 return -EINVAL; 304 return -EINVAL;
320 } 305 }
321 306
@@ -426,11 +411,11 @@ static int pcmcia_release_irq(struct pcmcia_device *p_dev, irq_req_t *req)
426 if (c->state & CONFIG_LOCKED) 411 if (c->state & CONFIG_LOCKED)
427 return -EACCES; 412 return -EACCES;
428 if (c->irq.Attributes != req->Attributes) { 413 if (c->irq.Attributes != req->Attributes) {
429 ds_dbg(s, 0, "IRQ attributes must match assigned ones\n"); 414 dev_dbg(&s->dev, "IRQ attributes must match assigned ones\n");
430 return -EINVAL; 415 return -EINVAL;
431 } 416 }
432 if (s->irq.AssignedIRQ != req->AssignedIRQ) { 417 if (s->irq.AssignedIRQ != req->AssignedIRQ) {
433 ds_dbg(s, 0, "IRQ must match assigned one\n"); 418 dev_dbg(&s->dev, "IRQ must match assigned one\n");
434 return -EINVAL; 419 return -EINVAL;
435 } 420 }
436 if (--s->irq.Config == 0) { 421 if (--s->irq.Config == 0) {
@@ -493,7 +478,7 @@ int pcmcia_request_configuration(struct pcmcia_device *p_dev,
493 return -ENODEV; 478 return -ENODEV;
494 479
495 if (req->IntType & INT_CARDBUS) { 480 if (req->IntType & INT_CARDBUS) {
496 ds_dbg(p_dev->socket, 0, "IntType may not be INT_CARDBUS\n"); 481 dev_dbg(&s->dev, "IntType may not be INT_CARDBUS\n");
497 return -EINVAL; 482 return -EINVAL;
498 } 483 }
499 c = p_dev->function_config; 484 c = p_dev->function_config;
@@ -619,31 +604,31 @@ int pcmcia_request_io(struct pcmcia_device *p_dev, io_req_t *req)
619 if (c->state & CONFIG_LOCKED) 604 if (c->state & CONFIG_LOCKED)
620 return -EACCES; 605 return -EACCES;
621 if (c->state & CONFIG_IO_REQ) { 606 if (c->state & CONFIG_IO_REQ) {
622 ds_dbg(s, 0, "IO already configured\n"); 607 dev_dbg(&s->dev, "IO already configured\n");
623 return -EBUSY; 608 return -EBUSY;
624 } 609 }
625 if (req->Attributes1 & (IO_SHARED | IO_FORCE_ALIAS_ACCESS)) { 610 if (req->Attributes1 & (IO_SHARED | IO_FORCE_ALIAS_ACCESS)) {
626 ds_dbg(s, 0, "bad attribute setting for IO region 1\n"); 611 dev_dbg(&s->dev, "bad attribute setting for IO region 1\n");
627 return -EINVAL; 612 return -EINVAL;
628 } 613 }
629 if ((req->NumPorts2 > 0) && 614 if ((req->NumPorts2 > 0) &&
630 (req->Attributes2 & (IO_SHARED | IO_FORCE_ALIAS_ACCESS))) { 615 (req->Attributes2 & (IO_SHARED | IO_FORCE_ALIAS_ACCESS))) {
631 ds_dbg(s, 0, "bad attribute setting for IO region 2\n"); 616 dev_dbg(&s->dev, "bad attribute setting for IO region 2\n");
632 return -EINVAL; 617 return -EINVAL;
633 } 618 }
634 619
635 ds_dbg(s, 1, "trying to allocate resource 1\n"); 620 dev_dbg(&s->dev, "trying to allocate resource 1\n");
636 if (alloc_io_space(s, req->Attributes1, &req->BasePort1, 621 if (alloc_io_space(s, req->Attributes1, &req->BasePort1,
637 req->NumPorts1, req->IOAddrLines)) { 622 req->NumPorts1, req->IOAddrLines)) {
638 ds_dbg(s, 0, "allocation of resource 1 failed\n"); 623 dev_dbg(&s->dev, "allocation of resource 1 failed\n");
639 return -EBUSY; 624 return -EBUSY;
640 } 625 }
641 626
642 if (req->NumPorts2) { 627 if (req->NumPorts2) {
643 ds_dbg(s, 1, "trying to allocate resource 2\n"); 628 dev_dbg(&s->dev, "trying to allocate resource 2\n");
644 if (alloc_io_space(s, req->Attributes2, &req->BasePort2, 629 if (alloc_io_space(s, req->Attributes2, &req->BasePort2,
645 req->NumPorts2, req->IOAddrLines)) { 630 req->NumPorts2, req->IOAddrLines)) {
646 ds_dbg(s, 0, "allocation of resource 2 failed\n"); 631 dev_dbg(&s->dev, "allocation of resource 2 failed\n");
647 release_io_space(s, req->BasePort1, req->NumPorts1); 632 release_io_space(s, req->BasePort1, req->NumPorts1);
648 return -EBUSY; 633 return -EBUSY;
649 } 634 }
@@ -687,7 +672,7 @@ int pcmcia_request_irq(struct pcmcia_device *p_dev, irq_req_t *req)
687 if (c->state & CONFIG_LOCKED) 672 if (c->state & CONFIG_LOCKED)
688 return -EACCES; 673 return -EACCES;
689 if (c->state & CONFIG_IRQ_REQ) { 674 if (c->state & CONFIG_IRQ_REQ) {
690 ds_dbg(s, 0, "IRQ already configured\n"); 675 dev_dbg(&s->dev, "IRQ already configured\n");
691 return -EBUSY; 676 return -EBUSY;
692 } 677 }
693 678
@@ -798,7 +783,7 @@ int pcmcia_request_window(struct pcmcia_device **p_dev, win_req_t *req, window_h
798 if (!(s->state & SOCKET_PRESENT)) 783 if (!(s->state & SOCKET_PRESENT))
799 return -ENODEV; 784 return -ENODEV;
800 if (req->Attributes & (WIN_PAGED | WIN_SHARED)) { 785 if (req->Attributes & (WIN_PAGED | WIN_SHARED)) {
801 ds_dbg(s, 0, "bad attribute setting for iomem region\n"); 786 dev_dbg(&s->dev, "bad attribute setting for iomem region\n");
802 return -EINVAL; 787 return -EINVAL;
803 } 788 }
804 789
@@ -809,12 +794,12 @@ int pcmcia_request_window(struct pcmcia_device **p_dev, win_req_t *req, window_h
809 (req->Attributes & WIN_STRICT_ALIGN)) ? 794 (req->Attributes & WIN_STRICT_ALIGN)) ?
810 req->Size : s->map_size); 795 req->Size : s->map_size);
811 if (req->Size & (s->map_size-1)) { 796 if (req->Size & (s->map_size-1)) {
812 ds_dbg(s, 0, "invalid map size\n"); 797 dev_dbg(&s->dev, "invalid map size\n");
813 return -EINVAL; 798 return -EINVAL;
814 } 799 }
815 if ((req->Base && (s->features & SS_CAP_STATIC_MAP)) || 800 if ((req->Base && (s->features & SS_CAP_STATIC_MAP)) ||
816 (req->Base & (align-1))) { 801 (req->Base & (align-1))) {
817 ds_dbg(s, 0, "invalid base address\n"); 802 dev_dbg(&s->dev, "invalid base address\n");
818 return -EINVAL; 803 return -EINVAL;
819 } 804 }
820 if (req->Base) 805 if (req->Base)
@@ -824,7 +809,7 @@ int pcmcia_request_window(struct pcmcia_device **p_dev, win_req_t *req, window_h
824 for (w = 0; w < MAX_WIN; w++) 809 for (w = 0; w < MAX_WIN; w++)
825 if (!(s->state & SOCKET_WIN_REQ(w))) break; 810 if (!(s->state & SOCKET_WIN_REQ(w))) break;
826 if (w == MAX_WIN) { 811 if (w == MAX_WIN) {
827 ds_dbg(s, 0, "all windows are used already\n"); 812 dev_dbg(&s->dev, "all windows are used already\n");
828 return -EINVAL; 813 return -EINVAL;
829 } 814 }
830 815
@@ -838,7 +823,7 @@ int pcmcia_request_window(struct pcmcia_device **p_dev, win_req_t *req, window_h
838 win->ctl.res = pcmcia_find_mem_region(req->Base, req->Size, align, 823 win->ctl.res = pcmcia_find_mem_region(req->Base, req->Size, align,
839 (req->Attributes & WIN_MAP_BELOW_1MB), s); 824 (req->Attributes & WIN_MAP_BELOW_1MB), s);
840 if (!win->ctl.res) { 825 if (!win->ctl.res) {
841 ds_dbg(s, 0, "allocating mem region failed\n"); 826 dev_dbg(&s->dev, "allocating mem region failed\n");
842 return -EINVAL; 827 return -EINVAL;
843 } 828 }
844 } 829 }
@@ -858,7 +843,7 @@ int pcmcia_request_window(struct pcmcia_device **p_dev, win_req_t *req, window_h
858 win->ctl.flags |= MAP_USE_WAIT; 843 win->ctl.flags |= MAP_USE_WAIT;
859 win->ctl.card_start = 0; 844 win->ctl.card_start = 0;
860 if (s->ops->set_mem_map(s, &win->ctl) != 0) { 845 if (s->ops->set_mem_map(s, &win->ctl) != 0) {
861 ds_dbg(s, 0, "failed to set memory mapping\n"); 846 dev_dbg(&s->dev, "failed to set memory mapping\n");
862 return -EIO; 847 return -EIO;
863 } 848 }
864 s->state |= SOCKET_WIN_REQ(w); 849 s->state |= SOCKET_WIN_REQ(w);