1 /* 2 * IBM Hot Plug Controller Driver 3 * 4 * Written By: Tong Yu, IBM Corporation 5 * 6 * Copyright (C) 2001,2003 Greg Kroah-Hartman (greg@kroah.com) 7 * Copyright (C) 2001-2003 IBM Corp. 8 * 9 * All rights reserved. 10 * 11 * This program is free software; you can redistribute it and/or modify 12 * it under the terms of the GNU General Public License as published by 13 * the Free Software Foundation; either version 2 of the License, or (at 14 * your option) any later version. 15 * 16 * This program is distributed in the hope that it will be useful, but 17 * WITHOUT ANY WARRANTY; without even the implied warranty of 18 * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or 19 * NON INFRINGEMENT. See the GNU General Public License for more 20 * details. 21 * 22 * You should have received a copy of the GNU General Public License 23 * along with this program; if not, write to the Free Software 24 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. 25 * 26 * Send feedback to <gregkh@us.ibm.com> 27 * 28 */ 29 30 #include <linux/module.h> 31 #include <linux/errno.h> 32 #include <linux/mm.h> 33 #include <linux/slab.h> 34 #include <linux/pci.h> 35 #include <linux/list.h> 36 #include <linux/init.h> 37 #include "ibmphp.h" 38 39 /* 40 * POST builds data blocks(in this data block definition, a char-1 41 * byte, short(or word)-2 byte, long(dword)-4 byte) in the Extended 42 * BIOS Data Area which describe the configuration of the hot-plug 43 * controllers and resources used by the PCI Hot-Plug devices. 44 * 45 * This file walks EBDA, maps data block from physical addr, 46 * reconstruct linked lists about all system resource(MEM, PFM, IO) 47 * already assigned by POST, as well as linked lists about hot plug 48 * controllers (ctlr#, slot#, bus&slot features...) 49 */ 50 51 /* Global lists */ 52 LIST_HEAD (ibmphp_ebda_pci_rsrc_head); 53 LIST_HEAD (ibmphp_slot_head); 54 55 /* Local variables */ 56 static struct ebda_hpc_list *hpc_list_ptr; 57 static struct ebda_rsrc_list *rsrc_list_ptr; 58 static struct rio_table_hdr *rio_table_ptr = NULL; 59 static LIST_HEAD (ebda_hpc_head); 60 static LIST_HEAD (bus_info_head); 61 static LIST_HEAD (rio_vg_head); 62 static LIST_HEAD (rio_lo_head); 63 static LIST_HEAD (opt_vg_head); 64 static LIST_HEAD (opt_lo_head); 65 static void __iomem *io_mem; 66 67 /* Local functions */ 68 static int ebda_rsrc_controller (void); 69 static int ebda_rsrc_rsrc (void); 70 static int ebda_rio_table (void); 71 72 static struct ebda_hpc_list * __init alloc_ebda_hpc_list (void) 73 { 74 return kzalloc(sizeof(struct ebda_hpc_list), GFP_KERNEL); 75 } 76 77 static struct controller *alloc_ebda_hpc (u32 slot_count, u32 bus_count) 78 { 79 struct controller *controller; 80 struct ebda_hpc_slot *slots; 81 struct ebda_hpc_bus *buses; 82 83 controller = kzalloc(sizeof(struct controller), GFP_KERNEL); 84 if (!controller) 85 goto error; 86 87 slots = kcalloc(slot_count, sizeof(struct ebda_hpc_slot), GFP_KERNEL); 88 if (!slots) 89 goto error_contr; 90 controller->slots = slots; 91 92 buses = kcalloc(bus_count, sizeof(struct ebda_hpc_bus), GFP_KERNEL); 93 if (!buses) 94 goto error_slots; 95 controller->buses = buses; 96 97 return controller; 98 error_slots: 99 kfree(controller->slots); 100 error_contr: 101 kfree(controller); 102 error: 103 return NULL; 104 } 105 106 static void free_ebda_hpc (struct controller *controller) 107 { 108 kfree (controller->slots); 109 kfree (controller->buses); 110 kfree (controller); 111 } 112 113 static struct ebda_rsrc_list * __init alloc_ebda_rsrc_list (void) 114 { 115 return kzalloc(sizeof(struct ebda_rsrc_list), GFP_KERNEL); 116 } 117 118 static struct ebda_pci_rsrc *alloc_ebda_pci_rsrc (void) 119 { 120 return kzalloc(sizeof(struct ebda_pci_rsrc), GFP_KERNEL); 121 } 122 123 static void __init print_bus_info (void) 124 { 125 struct bus_info *ptr; 126 struct list_head *ptr1; 127 128 list_for_each (ptr1, &bus_info_head) { 129 ptr = list_entry (ptr1, struct bus_info, bus_info_list); 130 debug ("%s - slot_min = %x\n", __FUNCTION__, ptr->slot_min); 131 debug ("%s - slot_max = %x\n", __FUNCTION__, ptr->slot_max); 132 debug ("%s - slot_count = %x\n", __FUNCTION__, ptr->slot_count); 133 debug ("%s - bus# = %x\n", __FUNCTION__, ptr->busno); 134 debug ("%s - current_speed = %x\n", __FUNCTION__, ptr->current_speed); 135 debug ("%s - controller_id = %x\n", __FUNCTION__, ptr->controller_id); 136 137 debug ("%s - slots_at_33_conv = %x\n", __FUNCTION__, ptr->slots_at_33_conv); 138 debug ("%s - slots_at_66_conv = %x\n", __FUNCTION__, ptr->slots_at_66_conv); 139 debug ("%s - slots_at_66_pcix = %x\n", __FUNCTION__, ptr->slots_at_66_pcix); 140 debug ("%s - slots_at_100_pcix = %x\n", __FUNCTION__, ptr->slots_at_100_pcix); 141 debug ("%s - slots_at_133_pcix = %x\n", __FUNCTION__, ptr->slots_at_133_pcix); 142 143 } 144 } 145 146 static void print_lo_info (void) 147 { 148 struct rio_detail *ptr; 149 struct list_head *ptr1; 150 debug ("print_lo_info ----\n"); 151 list_for_each (ptr1, &rio_lo_head) { 152 ptr = list_entry (ptr1, struct rio_detail, rio_detail_list); 153 debug ("%s - rio_node_id = %x\n", __FUNCTION__, ptr->rio_node_id); 154 debug ("%s - rio_type = %x\n", __FUNCTION__, ptr->rio_type); 155 debug ("%s - owner_id = %x\n", __FUNCTION__, ptr->owner_id); 156 debug ("%s - first_slot_num = %x\n", __FUNCTION__, ptr->first_slot_num); 157 debug ("%s - wpindex = %x\n", __FUNCTION__, ptr->wpindex); 158 debug ("%s - chassis_num = %x\n", __FUNCTION__, ptr->chassis_num); 159 160 } 161 } 162 163 static void print_vg_info (void) 164 { 165 struct rio_detail *ptr; 166 struct list_head *ptr1; 167 debug ("%s ---\n", __FUNCTION__); 168 list_for_each (ptr1, &rio_vg_head) { 169 ptr = list_entry (ptr1, struct rio_detail, rio_detail_list); 170 debug ("%s - rio_node_id = %x\n", __FUNCTION__, ptr->rio_node_id); 171 debug ("%s - rio_type = %x\n", __FUNCTION__, ptr->rio_type); 172 debug ("%s - owner_id = %x\n", __FUNCTION__, ptr->owner_id); 173 debug ("%s - first_slot_num = %x\n", __FUNCTION__, ptr->first_slot_num); 174 debug ("%s - wpindex = %x\n", __FUNCTION__, ptr->wpindex); 175 debug ("%s - chassis_num = %x\n", __FUNCTION__, ptr->chassis_num); 176 177 } 178 } 179 180 static void __init print_ebda_pci_rsrc (void) 181 { 182 struct ebda_pci_rsrc *ptr; 183 struct list_head *ptr1; 184 185 list_for_each (ptr1, &ibmphp_ebda_pci_rsrc_head) { 186 ptr = list_entry (ptr1, struct ebda_pci_rsrc, ebda_pci_rsrc_list); 187 debug ("%s - rsrc type: %x bus#: %x dev_func: %x start addr: %x end addr: %x\n", 188 __FUNCTION__, ptr->rsrc_type ,ptr->bus_num, ptr->dev_fun,ptr->start_addr, ptr->end_addr); 189 } 190 } 191 192 static void __init print_ibm_slot (void) 193 { 194 struct slot *ptr; 195 struct list_head *ptr1; 196 197 list_for_each (ptr1, &ibmphp_slot_head) { 198 ptr = list_entry (ptr1, struct slot, ibm_slot_list); 199 debug ("%s - slot_number: %x\n", __FUNCTION__, ptr->number); 200 } 201 } 202 203 static void __init print_opt_vg (void) 204 { 205 struct opt_rio *ptr; 206 struct list_head *ptr1; 207 debug ("%s ---\n", __FUNCTION__); 208 list_for_each (ptr1, &opt_vg_head) { 209 ptr = list_entry (ptr1, struct opt_rio, opt_rio_list); 210 debug ("%s - rio_type %x\n", __FUNCTION__, ptr->rio_type); 211 debug ("%s - chassis_num: %x\n", __FUNCTION__, ptr->chassis_num); 212 debug ("%s - first_slot_num: %x\n", __FUNCTION__, ptr->first_slot_num); 213 debug ("%s - middle_num: %x\n", __FUNCTION__, ptr->middle_num); 214 } 215 } 216 217 static void __init print_ebda_hpc (void) 218 { 219 struct controller *hpc_ptr; 220 struct list_head *ptr1; 221 u16 index; 222 223 list_for_each (ptr1, &ebda_hpc_head) { 224 225 hpc_ptr = list_entry (ptr1, struct controller, ebda_hpc_list); 226 227 for (index = 0; index < hpc_ptr->slot_count; index++) { 228 debug ("%s - physical slot#: %x\n", __FUNCTION__, hpc_ptr->slots[index].slot_num); 229 debug ("%s - pci bus# of the slot: %x\n", __FUNCTION__, hpc_ptr->slots[index].slot_bus_num); 230 debug ("%s - index into ctlr addr: %x\n", __FUNCTION__, hpc_ptr->slots[index].ctl_index); 231 debug ("%s - cap of the slot: %x\n", __FUNCTION__, hpc_ptr->slots[index].slot_cap); 232 } 233 234 for (index = 0; index < hpc_ptr->bus_count; index++) { 235 debug ("%s - bus# of each bus controlled by this ctlr: %x\n", __FUNCTION__, hpc_ptr->buses[index].bus_num); 236 } 237 238 debug ("%s - type of hpc: %x\n", __FUNCTION__, hpc_ptr->ctlr_type); 239 switch (hpc_ptr->ctlr_type) { 240 case 1: 241 debug ("%s - bus: %x\n", __FUNCTION__, hpc_ptr->u.pci_ctlr.bus); 242 debug ("%s - dev_fun: %x\n", __FUNCTION__, hpc_ptr->u.pci_ctlr.dev_fun); 243 debug ("%s - irq: %x\n", __FUNCTION__, hpc_ptr->irq); 244 break; 245 246 case 0: 247 debug ("%s - io_start: %x\n", __FUNCTION__, hpc_ptr->u.isa_ctlr.io_start); 248 debug ("%s - io_end: %x\n", __FUNCTION__, hpc_ptr->u.isa_ctlr.io_end); 249 debug ("%s - irq: %x\n", __FUNCTION__, hpc_ptr->irq); 250 break; 251 252 case 2: 253 case 4: 254 debug ("%s - wpegbbar: %lx\n", __FUNCTION__, hpc_ptr->u.wpeg_ctlr.wpegbbar); 255 debug ("%s - i2c_addr: %x\n", __FUNCTION__, hpc_ptr->u.wpeg_ctlr.i2c_addr); 256 debug ("%s - irq: %x\n", __FUNCTION__, hpc_ptr->irq); 257 break; 258 } 259 } 260 } 261 262 int __init ibmphp_access_ebda (void) 263 { 264 u8 format, num_ctlrs, rio_complete, hs_complete; 265 u16 ebda_seg, num_entries, next_offset, offset, blk_id, sub_addr, re, rc_id, re_id, base; 266 int rc = 0; 267 268 269 rio_complete = 0; 270 hs_complete = 0; 271 272 io_mem = ioremap ((0x40 << 4) + 0x0e, 2); 273 if (!io_mem ) 274 return -ENOMEM; 275 ebda_seg = readw (io_mem); 276 iounmap (io_mem); 277 debug ("returned ebda segment: %x\n", ebda_seg); 278 279 io_mem = ioremap (ebda_seg<<4, 65000); 280 if (!io_mem ) 281 return -ENOMEM; 282 next_offset = 0x180; 283 284 for (;;) { 285 offset = next_offset; 286 next_offset = readw (io_mem + offset); /* offset of next blk */ 287 288 offset += 2; 289 if (next_offset == 0) /* 0 indicate it's last blk */ 290 break; 291 blk_id = readw (io_mem + offset); /* this blk id */ 292 293 offset += 2; 294 /* check if it is hot swap block or rio block */ 295 if (blk_id != 0x4853 && blk_id != 0x4752) 296 continue; 297 /* found hs table */ 298 if (blk_id == 0x4853) { 299 debug ("now enter hot swap block---\n"); 300 debug ("hot blk id: %x\n", blk_id); 301 format = readb (io_mem + offset); 302 303 offset += 1; 304 if (format != 4) 305 goto error_nodev; 306 debug ("hot blk format: %x\n", format); 307 /* hot swap sub blk */ 308 base = offset; 309 310 sub_addr = base; 311 re = readw (io_mem + sub_addr); /* next sub blk */ 312 313 sub_addr += 2; 314 rc_id = readw (io_mem + sub_addr); /* sub blk id */ 315 316 sub_addr += 2; 317 if (rc_id != 0x5243) 318 goto error_nodev; 319 /* rc sub blk signature */ 320 num_ctlrs = readb (io_mem + sub_addr); 321 322 sub_addr += 1; 323 hpc_list_ptr = alloc_ebda_hpc_list (); 324 if (!hpc_list_ptr) { 325 rc = -ENOMEM; 326 goto out; 327 } 328 hpc_list_ptr->format = format; 329 hpc_list_ptr->num_ctlrs = num_ctlrs; 330 hpc_list_ptr->phys_addr = sub_addr; /* offset of RSRC_CONTROLLER blk */ 331 debug ("info about hpc descriptor---\n"); 332 debug ("hot blk format: %x\n", format); 333 debug ("num of controller: %x\n", num_ctlrs); 334 debug ("offset of hpc data structure enteries: %x\n ", sub_addr); 335 336 sub_addr = base + re; /* re sub blk */ 337 /* FIXME: rc is never used/checked */ 338 rc = readw (io_mem + sub_addr); /* next sub blk */ 339 340 sub_addr += 2; 341 re_id = readw (io_mem + sub_addr); /* sub blk id */ 342 343 sub_addr += 2; 344 if (re_id != 0x5245) 345 goto error_nodev; 346 347 /* signature of re */ 348 num_entries = readw (io_mem + sub_addr); 349 350 sub_addr += 2; /* offset of RSRC_ENTRIES blk */ 351 rsrc_list_ptr = alloc_ebda_rsrc_list (); 352 if (!rsrc_list_ptr ) { 353 rc = -ENOMEM; 354 goto out; 355 } 356 rsrc_list_ptr->format = format; 357 rsrc_list_ptr->num_entries = num_entries; 358 rsrc_list_ptr->phys_addr = sub_addr; 359 360 debug ("info about rsrc descriptor---\n"); 361 debug ("format: %x\n", format); 362 debug ("num of rsrc: %x\n", num_entries); 363 debug ("offset of rsrc data structure enteries: %x\n ", sub_addr); 364 365 hs_complete = 1; 366 } else { 367 /* found rio table, blk_id == 0x4752 */ 368 debug ("now enter io table ---\n"); 369 debug ("rio blk id: %x\n", blk_id); 370 371 rio_table_ptr = kzalloc(sizeof(struct rio_table_hdr), GFP_KERNEL); 372 if (!rio_table_ptr) 373 return -ENOMEM; 374 rio_table_ptr->ver_num = readb (io_mem + offset); 375 rio_table_ptr->scal_count = readb (io_mem + offset + 1); 376 rio_table_ptr->riodev_count = readb (io_mem + offset + 2); 377 rio_table_ptr->offset = offset +3 ; 378 379 debug("info about rio table hdr ---\n"); 380 debug("ver_num: %x\nscal_count: %x\nriodev_count: %x\noffset of rio table: %x\n ", 381 rio_table_ptr->ver_num, rio_table_ptr->scal_count, 382 rio_table_ptr->riodev_count, rio_table_ptr->offset); 383 384 rio_complete = 1; 385 } 386 } 387 388 if (!hs_complete && !rio_complete) 389 goto error_nodev; 390 391 if (rio_table_ptr) { 392 if (rio_complete && rio_table_ptr->ver_num == 3) { 393 rc = ebda_rio_table (); 394 if (rc) 395 goto out; 396 } 397 } 398 rc = ebda_rsrc_controller (); 399 if (rc) 400 goto out; 401 402 rc = ebda_rsrc_rsrc (); 403 goto out; 404 error_nodev: 405 rc = -ENODEV; 406 out: 407 iounmap (io_mem); 408 return rc; 409 } 410 411 /* 412 * map info of scalability details and rio details from physical address 413 */ 414 static int __init ebda_rio_table (void) 415 { 416 u16 offset; 417 u8 i; 418 struct rio_detail *rio_detail_ptr; 419 420 offset = rio_table_ptr->offset; 421 offset += 12 * rio_table_ptr->scal_count; 422 423 // we do concern about rio details 424 for (i = 0; i < rio_table_ptr->riodev_count; i++) { 425 rio_detail_ptr = kzalloc(sizeof(struct rio_detail), GFP_KERNEL); 426 if (!rio_detail_ptr) 427 return -ENOMEM; 428 rio_detail_ptr->rio_node_id = readb (io_mem + offset); 429 rio_detail_ptr->bbar = readl (io_mem + offset + 1); 430 rio_detail_ptr->rio_type = readb (io_mem + offset + 5); 431 rio_detail_ptr->owner_id = readb (io_mem + offset + 6); 432 rio_detail_ptr->port0_node_connect = readb (io_mem + offset + 7); 433 rio_detail_ptr->port0_port_connect = readb (io_mem + offset + 8); 434 rio_detail_ptr->port1_node_connect = readb (io_mem + offset + 9); 435 rio_detail_ptr->port1_port_connect = readb (io_mem + offset + 10); 436 rio_detail_ptr->first_slot_num = readb (io_mem + offset + 11); 437 rio_detail_ptr->status = readb (io_mem + offset + 12); 438 rio_detail_ptr->wpindex = readb (io_mem + offset + 13); 439 rio_detail_ptr->chassis_num = readb (io_mem + offset + 14); 440 // debug ("rio_node_id: %x\nbbar: %x\nrio_type: %x\nowner_id: %x\nport0_node: %x\nport0_port: %x\nport1_node: %x\nport1_port: %x\nfirst_slot_num: %x\nstatus: %x\n", rio_detail_ptr->rio_node_id, rio_detail_ptr->bbar, rio_detail_ptr->rio_type, rio_detail_ptr->owner_id, rio_detail_ptr->port0_node_connect, rio_detail_ptr->port0_port_connect, rio_detail_ptr->port1_node_connect, rio_detail_ptr->port1_port_connect, rio_detail_ptr->first_slot_num, rio_detail_ptr->status); 441 //create linked list of chassis 442 if (rio_detail_ptr->rio_type == 4 || rio_detail_ptr->rio_type == 5) 443 list_add (&rio_detail_ptr->rio_detail_list, &rio_vg_head); 444 //create linked list of expansion box 445 else if (rio_detail_ptr->rio_type == 6 || rio_detail_ptr->rio_type == 7) 446 list_add (&rio_detail_ptr->rio_detail_list, &rio_lo_head); 447 else 448 // not in my concern 449 kfree (rio_detail_ptr); 450 offset += 15; 451 } 452 print_lo_info (); 453 print_vg_info (); 454 return 0; 455 } 456 457 /* 458 * reorganizing linked list of chassis 459 */ 460 static struct opt_rio *search_opt_vg (u8 chassis_num) 461 { 462 struct opt_rio *ptr; 463 struct list_head *ptr1; 464 list_for_each (ptr1, &opt_vg_head) { 465 ptr = list_entry (ptr1, struct opt_rio, opt_rio_list); 466 if (ptr->chassis_num == chassis_num) 467 return ptr; 468 } 469 return NULL; 470 } 471 472 static int __init combine_wpg_for_chassis (void) 473 { 474 struct opt_rio *opt_rio_ptr = NULL; 475 struct rio_detail *rio_detail_ptr = NULL; 476 struct list_head *list_head_ptr = NULL; 477 478 list_for_each (list_head_ptr, &rio_vg_head) { 479 rio_detail_ptr = list_entry (list_head_ptr, struct rio_detail, rio_detail_list); 480 opt_rio_ptr = search_opt_vg (rio_detail_ptr->chassis_num); 481 if (!opt_rio_ptr) { 482 opt_rio_ptr = kzalloc(sizeof(struct opt_rio), GFP_KERNEL); 483 if (!opt_rio_ptr) 484 return -ENOMEM; 485 opt_rio_ptr->rio_type = rio_detail_ptr->rio_type; 486 opt_rio_ptr->chassis_num = rio_detail_ptr->chassis_num; 487 opt_rio_ptr->first_slot_num = rio_detail_ptr->first_slot_num; 488 opt_rio_ptr->middle_num = rio_detail_ptr->first_slot_num; 489 list_add (&opt_rio_ptr->opt_rio_list, &opt_vg_head); 490 } else { 491 opt_rio_ptr->first_slot_num = min (opt_rio_ptr->first_slot_num, rio_detail_ptr->first_slot_num); 492 opt_rio_ptr->middle_num = max (opt_rio_ptr->middle_num, rio_detail_ptr->first_slot_num); 493 } 494 } 495 print_opt_vg (); 496 return 0; 497 } 498 499 /* 500 * reorgnizing linked list of expansion box 501 */ 502 static struct opt_rio_lo *search_opt_lo (u8 chassis_num) 503 { 504 struct opt_rio_lo *ptr; 505 struct list_head *ptr1; 506 list_for_each (ptr1, &opt_lo_head) { 507 ptr = list_entry (ptr1, struct opt_rio_lo, opt_rio_lo_list); 508 if (ptr->chassis_num == chassis_num) 509 return ptr; 510 } 511 return NULL; 512 } 513 514 static int combine_wpg_for_expansion (void) 515 { 516 struct opt_rio_lo *opt_rio_lo_ptr = NULL; 517 struct rio_detail *rio_detail_ptr = NULL; 518 struct list_head *list_head_ptr = NULL; 519 520 list_for_each (list_head_ptr, &rio_lo_head) { 521 rio_detail_ptr = list_entry (list_head_ptr, struct rio_detail, rio_detail_list); 522 opt_rio_lo_ptr = search_opt_lo (rio_detail_ptr->chassis_num); 523 if (!opt_rio_lo_ptr) { 524 opt_rio_lo_ptr = kzalloc(sizeof(struct opt_rio_lo), GFP_KERNEL); 525 if (!opt_rio_lo_ptr) 526 return -ENOMEM; 527 opt_rio_lo_ptr->rio_type = rio_detail_ptr->rio_type; 528 opt_rio_lo_ptr->chassis_num = rio_detail_ptr->chassis_num; 529 opt_rio_lo_ptr->first_slot_num = rio_detail_ptr->first_slot_num; 530 opt_rio_lo_ptr->middle_num = rio_detail_ptr->first_slot_num; 531 opt_rio_lo_ptr->pack_count = 1; 532 533 list_add (&opt_rio_lo_ptr->opt_rio_lo_list, &opt_lo_head); 534 } else { 535 opt_rio_lo_ptr->first_slot_num = min (opt_rio_lo_ptr->first_slot_num, rio_detail_ptr->first_slot_num); 536 opt_rio_lo_ptr->middle_num = max (opt_rio_lo_ptr->middle_num, rio_detail_ptr->first_slot_num); 537 opt_rio_lo_ptr->pack_count = 2; 538 } 539 } 540 return 0; 541 } 542 543 544 /* Since we don't know the max slot number per each chassis, hence go 545 * through the list of all chassis to find out the range 546 * Arguments: slot_num, 1st slot number of the chassis we think we are on, 547 * var (0 = chassis, 1 = expansion box) 548 */ 549 static int first_slot_num (u8 slot_num, u8 first_slot, u8 var) 550 { 551 struct opt_rio *opt_vg_ptr = NULL; 552 struct opt_rio_lo *opt_lo_ptr = NULL; 553 struct list_head *ptr = NULL; 554 int rc = 0; 555 556 if (!var) { 557 list_for_each (ptr, &opt_vg_head) { 558 opt_vg_ptr = list_entry (ptr, struct opt_rio, opt_rio_list); 559 if ((first_slot < opt_vg_ptr->first_slot_num) && (slot_num >= opt_vg_ptr->first_slot_num)) { 560 rc = -ENODEV; 561 break; 562 } 563 } 564 } else { 565 list_for_each (ptr, &opt_lo_head) { 566 opt_lo_ptr = list_entry (ptr, struct opt_rio_lo, opt_rio_lo_list); 567 if ((first_slot < opt_lo_ptr->first_slot_num) && (slot_num >= opt_lo_ptr->first_slot_num)) { 568 rc = -ENODEV; 569 break; 570 } 571 } 572 } 573 return rc; 574 } 575 576 static struct opt_rio_lo * find_rxe_num (u8 slot_num) 577 { 578 struct opt_rio_lo *opt_lo_ptr; 579 struct list_head *ptr; 580 581 list_for_each (ptr, &opt_lo_head) { 582 opt_lo_ptr = list_entry (ptr, struct opt_rio_lo, opt_rio_lo_list); 583 //check to see if this slot_num belongs to expansion box 584 if ((slot_num >= opt_lo_ptr->first_slot_num) && (!first_slot_num (slot_num, opt_lo_ptr->first_slot_num, 1))) 585 return opt_lo_ptr; 586 } 587 return NULL; 588 } 589 590 static struct opt_rio * find_chassis_num (u8 slot_num) 591 { 592 struct opt_rio *opt_vg_ptr; 593 struct list_head *ptr; 594 595 list_for_each (ptr, &opt_vg_head) { 596 opt_vg_ptr = list_entry (ptr, struct opt_rio, opt_rio_list); 597 //check to see if this slot_num belongs to chassis 598 if ((slot_num >= opt_vg_ptr->first_slot_num) && (!first_slot_num (slot_num, opt_vg_ptr->first_slot_num, 0))) 599 return opt_vg_ptr; 600 } 601 return NULL; 602 } 603 604 /* This routine will find out how many slots are in the chassis, so that 605 * the slot numbers for rxe100 would start from 1, and not from 7, or 6 etc 606 */ 607 static u8 calculate_first_slot (u8 slot_num) 608 { 609 u8 first_slot = 1; 610 struct list_head * list; 611 struct slot * slot_cur; 612 613 list_for_each (list, &ibmphp_slot_head) { 614 slot_cur = list_entry (list, struct slot, ibm_slot_list); 615 if (slot_cur->ctrl) { 616 if ((slot_cur->ctrl->ctlr_type != 4) && (slot_cur->ctrl->ending_slot_num > first_slot) && (slot_num > slot_cur->ctrl->ending_slot_num)) 617 first_slot = slot_cur->ctrl->ending_slot_num; 618 } 619 } 620 return first_slot + 1; 621 622 } 623 static char *create_file_name (struct slot * slot_cur) 624 { 625 struct opt_rio *opt_vg_ptr = NULL; 626 struct opt_rio_lo *opt_lo_ptr = NULL; 627 static char str[30]; 628 int which = 0; /* rxe = 1, chassis = 0 */ 629 u8 number = 1; /* either chassis or rxe # */ 630 u8 first_slot = 1; 631 u8 slot_num; 632 u8 flag = 0; 633 634 if (!slot_cur) { 635 err ("Structure passed is empty\n"); 636 return NULL; 637 } 638 639 slot_num = slot_cur->number; 640 641 memset (str, 0, sizeof(str)); 642 643 if (rio_table_ptr) { 644 if (rio_table_ptr->ver_num == 3) { 645 opt_vg_ptr = find_chassis_num (slot_num); 646 opt_lo_ptr = find_rxe_num (slot_num); 647 } 648 } 649 if (opt_vg_ptr) { 650 if (opt_lo_ptr) { 651 if ((slot_num - opt_vg_ptr->first_slot_num) > (slot_num - opt_lo_ptr->first_slot_num)) { 652 number = opt_lo_ptr->chassis_num; 653 first_slot = opt_lo_ptr->first_slot_num; 654 which = 1; /* it is RXE */ 655 } else { 656 first_slot = opt_vg_ptr->first_slot_num; 657 number = opt_vg_ptr->chassis_num; 658 which = 0; 659 } 660 } else { 661 first_slot = opt_vg_ptr->first_slot_num; 662 number = opt_vg_ptr->chassis_num; 663 which = 0; 664 } 665 ++flag; 666 } else if (opt_lo_ptr) { 667 number = opt_lo_ptr->chassis_num; 668 first_slot = opt_lo_ptr->first_slot_num; 669 which = 1; 670 ++flag; 671 } else if (rio_table_ptr) { 672 if (rio_table_ptr->ver_num == 3) { 673 /* if both NULL and we DO have correct RIO table in BIOS */ 674 return NULL; 675 } 676 } 677 if (!flag) { 678 if (slot_cur->ctrl->ctlr_type == 4) { 679 first_slot = calculate_first_slot (slot_num); 680 which = 1; 681 } else { 682 which = 0; 683 } 684 } 685 686 sprintf(str, "%s%dslot%d", 687 which == 0 ? "chassis" : "rxe", 688 number, slot_num - first_slot + 1); 689 return str; 690 } 691 692 static int fillslotinfo(struct hotplug_slot *hotplug_slot) 693 { 694 struct slot *slot; 695 int rc = 0; 696 697 if (!hotplug_slot || !hotplug_slot->private) 698 return -EINVAL; 699 700 slot = hotplug_slot->private; 701 rc = ibmphp_hpc_readslot(slot, READ_ALLSTAT, NULL); 702 if (rc) 703 return rc; 704 705 // power - enabled:1 not:0 706 hotplug_slot->info->power_status = SLOT_POWER(slot->status); 707 708 // attention - off:0, on:1, blinking:2 709 hotplug_slot->info->attention_status = SLOT_ATTN(slot->status, slot->ext_status); 710 711 // latch - open:1 closed:0 712 hotplug_slot->info->latch_status = SLOT_LATCH(slot->status); 713 714 // pci board - present:1 not:0 715 if (SLOT_PRESENT (slot->status)) 716 hotplug_slot->info->adapter_status = 1; 717 else 718 hotplug_slot->info->adapter_status = 0; 719 /* 720 if (slot->bus_on->supported_bus_mode 721 && (slot->bus_on->supported_speed == BUS_SPEED_66)) 722 hotplug_slot->info->max_bus_speed_status = BUS_SPEED_66PCIX; 723 else 724 hotplug_slot->info->max_bus_speed_status = slot->bus_on->supported_speed; 725 */ 726 727 return rc; 728 } 729 730 static void release_slot(struct hotplug_slot *hotplug_slot) 731 { 732 struct slot *slot; 733 734 if (!hotplug_slot || !hotplug_slot->private) 735 return; 736 737 slot = hotplug_slot->private; 738 kfree(slot->hotplug_slot->info); 739 kfree(slot->hotplug_slot->name); 740 kfree(slot->hotplug_slot); 741 slot->ctrl = NULL; 742 slot->bus_on = NULL; 743 744 /* we don't want to actually remove the resources, since free_resources will do just that */ 745 ibmphp_unconfigure_card(&slot, -1); 746 747 kfree (slot); 748 } 749 750 static struct pci_driver ibmphp_driver; 751 752 /* 753 * map info (ctlr-id, slot count, slot#.. bus count, bus#, ctlr type...) of 754 * each hpc from physical address to a list of hot plug controllers based on 755 * hpc descriptors. 756 */ 757 static int __init ebda_rsrc_controller (void) 758 { 759 u16 addr, addr_slot, addr_bus; 760 u8 ctlr_id, temp, bus_index; 761 u16 ctlr, slot, bus; 762 u16 slot_num, bus_num, index; 763 struct hotplug_slot *hp_slot_ptr; 764 struct controller *hpc_ptr; 765 struct ebda_hpc_bus *bus_ptr; 766 struct ebda_hpc_slot *slot_ptr; 767 struct bus_info *bus_info_ptr1, *bus_info_ptr2; 768 int rc; 769 struct slot *tmp_slot; 770 struct list_head *list; 771 772 addr = hpc_list_ptr->phys_addr; 773 for (ctlr = 0; ctlr < hpc_list_ptr->num_ctlrs; ctlr++) { 774 bus_index = 1; 775 ctlr_id = readb (io_mem + addr); 776 addr += 1; 777 slot_num = readb (io_mem + addr); 778 779 addr += 1; 780 addr_slot = addr; /* offset of slot structure */ 781 addr += (slot_num * 4); 782 783 bus_num = readb (io_mem + addr); 784 785 addr += 1; 786 addr_bus = addr; /* offset of bus */ 787 addr += (bus_num * 9); /* offset of ctlr_type */ 788 temp = readb (io_mem + addr); 789 790 addr += 1; 791 /* init hpc structure */ 792 hpc_ptr = alloc_ebda_hpc (slot_num, bus_num); 793 if (!hpc_ptr ) { 794 rc = -ENOMEM; 795 goto error_no_hpc; 796 } 797 hpc_ptr->ctlr_id = ctlr_id; 798 hpc_ptr->ctlr_relative_id = ctlr; 799 hpc_ptr->slot_count = slot_num; 800 hpc_ptr->bus_count = bus_num; 801 debug ("now enter ctlr data struture ---\n"); 802 debug ("ctlr id: %x\n", ctlr_id); 803 debug ("ctlr_relative_id: %x\n", hpc_ptr->ctlr_relative_id); 804 debug ("count of slots controlled by this ctlr: %x\n", slot_num); 805 debug ("count of buses controlled by this ctlr: %x\n", bus_num); 806 807 /* init slot structure, fetch slot, bus, cap... */ 808 slot_ptr = hpc_ptr->slots; 809 for (slot = 0; slot < slot_num; slot++) { 810 slot_ptr->slot_num = readb (io_mem + addr_slot); 811 slot_ptr->slot_bus_num = readb (io_mem + addr_slot + slot_num); 812 slot_ptr->ctl_index = readb (io_mem + addr_slot + 2*slot_num); 813 slot_ptr->slot_cap = readb (io_mem + addr_slot + 3*slot_num); 814 815 // create bus_info lined list --- if only one slot per bus: slot_min = slot_max 816 817 bus_info_ptr2 = ibmphp_find_same_bus_num (slot_ptr->slot_bus_num); 818 if (!bus_info_ptr2) { 819 bus_info_ptr1 = kzalloc(sizeof(struct bus_info), GFP_KERNEL); 820 if (!bus_info_ptr1) { 821 rc = -ENOMEM; 822 goto error_no_hp_slot; 823 } 824 bus_info_ptr1->slot_min = slot_ptr->slot_num; 825 bus_info_ptr1->slot_max = slot_ptr->slot_num; 826 bus_info_ptr1->slot_count += 1; 827 bus_info_ptr1->busno = slot_ptr->slot_bus_num; 828 bus_info_ptr1->index = bus_index++; 829 bus_info_ptr1->current_speed = 0xff; 830 bus_info_ptr1->current_bus_mode = 0xff; 831 832 bus_info_ptr1->controller_id = hpc_ptr->ctlr_id; 833 834 list_add_tail (&bus_info_ptr1->bus_info_list, &bus_info_head); 835 836 } else { 837 bus_info_ptr2->slot_min = min (bus_info_ptr2->slot_min, slot_ptr->slot_num); 838 bus_info_ptr2->slot_max = max (bus_info_ptr2->slot_max, slot_ptr->slot_num); 839 bus_info_ptr2->slot_count += 1; 840 841 } 842 843 // end of creating the bus_info linked list 844 845 slot_ptr++; 846 addr_slot += 1; 847 } 848 849 /* init bus structure */ 850 bus_ptr = hpc_ptr->buses; 851 for (bus = 0; bus < bus_num; bus++) { 852 bus_ptr->bus_num = readb (io_mem + addr_bus + bus); 853 bus_ptr->slots_at_33_conv = readb (io_mem + addr_bus + bus_num + 8 * bus); 854 bus_ptr->slots_at_66_conv = readb (io_mem + addr_bus + bus_num + 8 * bus + 1); 855 856 bus_ptr->slots_at_66_pcix = readb (io_mem + addr_bus + bus_num + 8 * bus + 2); 857 858 bus_ptr->slots_at_100_pcix = readb (io_mem + addr_bus + bus_num + 8 * bus + 3); 859 860 bus_ptr->slots_at_133_pcix = readb (io_mem + addr_bus + bus_num + 8 * bus + 4); 861 862 bus_info_ptr2 = ibmphp_find_same_bus_num (bus_ptr->bus_num); 863 if (bus_info_ptr2) { 864 bus_info_ptr2->slots_at_33_conv = bus_ptr->slots_at_33_conv; 865 bus_info_ptr2->slots_at_66_conv = bus_ptr->slots_at_66_conv; 866 bus_info_ptr2->slots_at_66_pcix = bus_ptr->slots_at_66_pcix; 867 bus_info_ptr2->slots_at_100_pcix = bus_ptr->slots_at_100_pcix; 868 bus_info_ptr2->slots_at_133_pcix = bus_ptr->slots_at_133_pcix; 869 } 870 bus_ptr++; 871 } 872 873 hpc_ptr->ctlr_type = temp; 874 875 switch (hpc_ptr->ctlr_type) { 876 case 1: 877 hpc_ptr->u.pci_ctlr.bus = readb (io_mem + addr); 878 hpc_ptr->u.pci_ctlr.dev_fun = readb (io_mem + addr + 1); 879 hpc_ptr->irq = readb (io_mem + addr + 2); 880 addr += 3; 881 debug ("ctrl bus = %x, ctlr devfun = %x, irq = %x\n", 882 hpc_ptr->u.pci_ctlr.bus, 883 hpc_ptr->u.pci_ctlr.dev_fun, hpc_ptr->irq); 884 break; 885 886 case 0: 887 hpc_ptr->u.isa_ctlr.io_start = readw (io_mem + addr); 888 hpc_ptr->u.isa_ctlr.io_end = readw (io_mem + addr + 2); 889 if (!request_region (hpc_ptr->u.isa_ctlr.io_start, 890 (hpc_ptr->u.isa_ctlr.io_end - hpc_ptr->u.isa_ctlr.io_start + 1), 891 "ibmphp")) { 892 rc = -ENODEV; 893 goto error_no_hp_slot; 894 } 895 hpc_ptr->irq = readb (io_mem + addr + 4); 896 addr += 5; 897 break; 898 899 case 2: 900 case 4: 901 hpc_ptr->u.wpeg_ctlr.wpegbbar = readl (io_mem + addr); 902 hpc_ptr->u.wpeg_ctlr.i2c_addr = readb (io_mem + addr + 4); 903 hpc_ptr->irq = readb (io_mem + addr + 5); 904 addr += 6; 905 break; 906 default: 907 rc = -ENODEV; 908 goto error_no_hp_slot; 909 } 910 911 //reorganize chassis' linked list 912 combine_wpg_for_chassis (); 913 combine_wpg_for_expansion (); 914 hpc_ptr->revision = 0xff; 915 hpc_ptr->options = 0xff; 916 hpc_ptr->starting_slot_num = hpc_ptr->slots[0].slot_num; 917 hpc_ptr->ending_slot_num = hpc_ptr->slots[slot_num-1].slot_num; 918 919 // register slots with hpc core as well as create linked list of ibm slot 920 for (index = 0; index < hpc_ptr->slot_count; index++) { 921 922 hp_slot_ptr = kzalloc(sizeof(*hp_slot_ptr), GFP_KERNEL); 923 if (!hp_slot_ptr) { 924 rc = -ENOMEM; 925 goto error_no_hp_slot; 926 } 927 928 hp_slot_ptr->info = kzalloc(sizeof(struct hotplug_slot_info), GFP_KERNEL); 929 if (!hp_slot_ptr->info) { 930 rc = -ENOMEM; 931 goto error_no_hp_info; 932 } 933 934 hp_slot_ptr->name = kmalloc(30, GFP_KERNEL); 935 if (!hp_slot_ptr->name) { 936 rc = -ENOMEM; 937 goto error_no_hp_name; 938 } 939 940 tmp_slot = kzalloc(sizeof(*tmp_slot), GFP_KERNEL); 941 if (!tmp_slot) { 942 rc = -ENOMEM; 943 goto error_no_slot; 944 } 945 946 tmp_slot->flag = 1; 947 948 tmp_slot->capabilities = hpc_ptr->slots[index].slot_cap; 949 if ((hpc_ptr->slots[index].slot_cap & EBDA_SLOT_133_MAX) == EBDA_SLOT_133_MAX) 950 tmp_slot->supported_speed = 3; 951 else if ((hpc_ptr->slots[index].slot_cap & EBDA_SLOT_100_MAX) == EBDA_SLOT_100_MAX) 952 tmp_slot->supported_speed = 2; 953 else if ((hpc_ptr->slots[index].slot_cap & EBDA_SLOT_66_MAX) == EBDA_SLOT_66_MAX) 954 tmp_slot->supported_speed = 1; 955 956 if ((hpc_ptr->slots[index].slot_cap & EBDA_SLOT_PCIX_CAP) == EBDA_SLOT_PCIX_CAP) 957 tmp_slot->supported_bus_mode = 1; 958 else 959 tmp_slot->supported_bus_mode = 0; 960 961 962 tmp_slot->bus = hpc_ptr->slots[index].slot_bus_num; 963 964 bus_info_ptr1 = ibmphp_find_same_bus_num (hpc_ptr->slots[index].slot_bus_num); 965 if (!bus_info_ptr1) { 966 rc = -ENODEV; 967 goto error; 968 } 969 tmp_slot->bus_on = bus_info_ptr1; 970 bus_info_ptr1 = NULL; 971 tmp_slot->ctrl = hpc_ptr; 972 973 tmp_slot->ctlr_index = hpc_ptr->slots[index].ctl_index; 974 tmp_slot->number = hpc_ptr->slots[index].slot_num; 975 tmp_slot->hotplug_slot = hp_slot_ptr; 976 977 hp_slot_ptr->private = tmp_slot; 978 hp_slot_ptr->release = release_slot; 979 980 rc = fillslotinfo(hp_slot_ptr); 981 if (rc) 982 goto error; 983 984 rc = ibmphp_init_devno ((struct slot **) &hp_slot_ptr->private); 985 if (rc) 986 goto error; 987 hp_slot_ptr->ops = &ibmphp_hotplug_slot_ops; 988 989 // end of registering ibm slot with hotplug core 990 991 list_add (& ((struct slot *)(hp_slot_ptr->private))->ibm_slot_list, &ibmphp_slot_head); 992 } 993 994 print_bus_info (); 995 list_add (&hpc_ptr->ebda_hpc_list, &ebda_hpc_head ); 996 997 } /* each hpc */ 998 999 list_for_each (list, &ibmphp_slot_head) { 1000 tmp_slot = list_entry (list, struct slot, ibm_slot_list); 1001 1002 snprintf (tmp_slot->hotplug_slot->name, 30, "%s", create_file_name (tmp_slot)); 1003 pci_hp_register (tmp_slot->hotplug_slot); 1004 } 1005 1006 print_ebda_hpc (); 1007 print_ibm_slot (); 1008 return 0; 1009 1010 error: 1011 kfree (hp_slot_ptr->private); 1012 error_no_slot: 1013 kfree (hp_slot_ptr->name); 1014 error_no_hp_name: 1015 kfree (hp_slot_ptr->info); 1016 error_no_hp_info: 1017 kfree (hp_slot_ptr); 1018 error_no_hp_slot: 1019 free_ebda_hpc (hpc_ptr); 1020 error_no_hpc: 1021 iounmap (io_mem); 1022 return rc; 1023 } 1024 1025 /* 1026 * map info (bus, devfun, start addr, end addr..) of i/o, memory, 1027 * pfm from the physical addr to a list of resource. 1028 */ 1029 static int __init ebda_rsrc_rsrc (void) 1030 { 1031 u16 addr; 1032 short rsrc; 1033 u8 type, rsrc_type; 1034 struct ebda_pci_rsrc *rsrc_ptr; 1035 1036 addr = rsrc_list_ptr->phys_addr; 1037 debug ("now entering rsrc land\n"); 1038 debug ("offset of rsrc: %x\n", rsrc_list_ptr->phys_addr); 1039 1040 for (rsrc = 0; rsrc < rsrc_list_ptr->num_entries; rsrc++) { 1041 type = readb (io_mem + addr); 1042 1043 addr += 1; 1044 rsrc_type = type & EBDA_RSRC_TYPE_MASK; 1045 1046 if (rsrc_type == EBDA_IO_RSRC_TYPE) { 1047 rsrc_ptr = alloc_ebda_pci_rsrc (); 1048 if (!rsrc_ptr) { 1049 iounmap (io_mem); 1050 return -ENOMEM; 1051 } 1052 rsrc_ptr->rsrc_type = type; 1053 1054 rsrc_ptr->bus_num = readb (io_mem + addr); 1055 rsrc_ptr->dev_fun = readb (io_mem + addr + 1); 1056 rsrc_ptr->start_addr = readw (io_mem + addr + 2); 1057 rsrc_ptr->end_addr = readw (io_mem + addr + 4); 1058 addr += 6; 1059 1060 debug ("rsrc from io type ----\n"); 1061 debug ("rsrc type: %x bus#: %x dev_func: %x start addr: %x end addr: %x\n", 1062 rsrc_ptr->rsrc_type, rsrc_ptr->bus_num, rsrc_ptr->dev_fun, rsrc_ptr->start_addr, rsrc_ptr->end_addr); 1063 1064 list_add (&rsrc_ptr->ebda_pci_rsrc_list, &ibmphp_ebda_pci_rsrc_head); 1065 } 1066 1067 if (rsrc_type == EBDA_MEM_RSRC_TYPE || rsrc_type == EBDA_PFM_RSRC_TYPE) { 1068 rsrc_ptr = alloc_ebda_pci_rsrc (); 1069 if (!rsrc_ptr ) { 1070 iounmap (io_mem); 1071 return -ENOMEM; 1072 } 1073 rsrc_ptr->rsrc_type = type; 1074 1075 rsrc_ptr->bus_num = readb (io_mem + addr); 1076 rsrc_ptr->dev_fun = readb (io_mem + addr + 1); 1077 rsrc_ptr->start_addr = readl (io_mem + addr + 2); 1078 rsrc_ptr->end_addr = readl (io_mem + addr + 6); 1079 addr += 10; 1080 1081 debug ("rsrc from mem or pfm ---\n"); 1082 debug ("rsrc type: %x bus#: %x dev_func: %x start addr: %x end addr: %x\n", 1083 rsrc_ptr->rsrc_type, rsrc_ptr->bus_num, rsrc_ptr->dev_fun, rsrc_ptr->start_addr, rsrc_ptr->end_addr); 1084 1085 list_add (&rsrc_ptr->ebda_pci_rsrc_list, &ibmphp_ebda_pci_rsrc_head); 1086 } 1087 } 1088 kfree (rsrc_list_ptr); 1089 rsrc_list_ptr = NULL; 1090 print_ebda_pci_rsrc (); 1091 return 0; 1092 } 1093 1094 u16 ibmphp_get_total_controllers (void) 1095 { 1096 return hpc_list_ptr->num_ctlrs; 1097 } 1098 1099 struct slot *ibmphp_get_slot_from_physical_num (u8 physical_num) 1100 { 1101 struct slot *slot; 1102 struct list_head *list; 1103 1104 list_for_each (list, &ibmphp_slot_head) { 1105 slot = list_entry (list, struct slot, ibm_slot_list); 1106 if (slot->number == physical_num) 1107 return slot; 1108 } 1109 return NULL; 1110 } 1111 1112 /* To find: 1113 * - the smallest slot number 1114 * - the largest slot number 1115 * - the total number of the slots based on each bus 1116 * (if only one slot per bus slot_min = slot_max ) 1117 */ 1118 struct bus_info *ibmphp_find_same_bus_num (u32 num) 1119 { 1120 struct bus_info *ptr; 1121 struct list_head *ptr1; 1122 1123 list_for_each (ptr1, &bus_info_head) { 1124 ptr = list_entry (ptr1, struct bus_info, bus_info_list); 1125 if (ptr->busno == num) 1126 return ptr; 1127 } 1128 return NULL; 1129 } 1130 1131 /* Finding relative bus number, in order to map corresponding 1132 * bus register 1133 */ 1134 int ibmphp_get_bus_index (u8 num) 1135 { 1136 struct bus_info *ptr; 1137 struct list_head *ptr1; 1138 1139 list_for_each (ptr1, &bus_info_head) { 1140 ptr = list_entry (ptr1, struct bus_info, bus_info_list); 1141 if (ptr->busno == num) 1142 return ptr->index; 1143 } 1144 return -ENODEV; 1145 } 1146 1147 void ibmphp_free_bus_info_queue (void) 1148 { 1149 struct bus_info *bus_info; 1150 struct list_head *list; 1151 struct list_head *next; 1152 1153 list_for_each_safe (list, next, &bus_info_head ) { 1154 bus_info = list_entry (list, struct bus_info, bus_info_list); 1155 kfree (bus_info); 1156 } 1157 } 1158 1159 void ibmphp_free_ebda_hpc_queue (void) 1160 { 1161 struct controller *controller = NULL; 1162 struct list_head *list; 1163 struct list_head *next; 1164 int pci_flag = 0; 1165 1166 list_for_each_safe (list, next, &ebda_hpc_head) { 1167 controller = list_entry (list, struct controller, ebda_hpc_list); 1168 if (controller->ctlr_type == 0) 1169 release_region (controller->u.isa_ctlr.io_start, (controller->u.isa_ctlr.io_end - controller->u.isa_ctlr.io_start + 1)); 1170 else if ((controller->ctlr_type == 1) && (!pci_flag)) { 1171 ++pci_flag; 1172 pci_unregister_driver (&ibmphp_driver); 1173 } 1174 free_ebda_hpc (controller); 1175 } 1176 } 1177 1178 void ibmphp_free_ebda_pci_rsrc_queue (void) 1179 { 1180 struct ebda_pci_rsrc *resource; 1181 struct list_head *list; 1182 struct list_head *next; 1183 1184 list_for_each_safe (list, next, &ibmphp_ebda_pci_rsrc_head) { 1185 resource = list_entry (list, struct ebda_pci_rsrc, ebda_pci_rsrc_list); 1186 kfree (resource); 1187 resource = NULL; 1188 } 1189 } 1190 1191 static struct pci_device_id id_table[] = { 1192 { 1193 .vendor = PCI_VENDOR_ID_IBM, 1194 .device = HPC_DEVICE_ID, 1195 .subvendor = PCI_VENDOR_ID_IBM, 1196 .subdevice = HPC_SUBSYSTEM_ID, 1197 .class = ((PCI_CLASS_SYSTEM_PCI_HOTPLUG << 8) | 0x00), 1198 }, {} 1199 }; 1200 1201 MODULE_DEVICE_TABLE(pci, id_table); 1202 1203 static int ibmphp_probe (struct pci_dev *, const struct pci_device_id *); 1204 static struct pci_driver ibmphp_driver = { 1205 .name = "ibmphp", 1206 .id_table = id_table, 1207 .probe = ibmphp_probe, 1208 }; 1209 1210 int ibmphp_register_pci (void) 1211 { 1212 struct controller *ctrl; 1213 struct list_head *tmp; 1214 int rc = 0; 1215 1216 list_for_each (tmp, &ebda_hpc_head) { 1217 ctrl = list_entry (tmp, struct controller, ebda_hpc_list); 1218 if (ctrl->ctlr_type == 1) { 1219 rc = pci_register_driver(&ibmphp_driver); 1220 break; 1221 } 1222 } 1223 return rc; 1224 } 1225 static int ibmphp_probe (struct pci_dev * dev, const struct pci_device_id *ids) 1226 { 1227 struct controller *ctrl; 1228 struct list_head *tmp; 1229 1230 debug ("inside ibmphp_probe\n"); 1231 1232 list_for_each (tmp, &ebda_hpc_head) { 1233 ctrl = list_entry (tmp, struct controller, ebda_hpc_list); 1234 if (ctrl->ctlr_type == 1) { 1235 if ((dev->devfn == ctrl->u.pci_ctlr.dev_fun) && (dev->bus->number == ctrl->u.pci_ctlr.bus)) { 1236 ctrl->ctrl_dev = dev; 1237 debug ("found device!!!\n"); 1238 debug ("dev->device = %x, dev->subsystem_device = %x\n", dev->device, dev->subsystem_device); 1239 return 0; 1240 } 1241 } 1242 } 1243 return -ENODEV; 1244 } 1245 1246