1 /* 2 * CDDL HEADER START 3 * 4 * The contents of this file are subject to the terms of the 5 * Common Development and Distribution License (the "License"). 6 * You may not use this file except in compliance with the License. 7 * 8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9 * or http://www.opensolaris.org/os/licensing. 10 * See the License for the specific language governing permissions 11 * and limitations under the License. 12 * 13 * When distributing Covered Code, include this CDDL HEADER in each 14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15 * If applicable, add the following below this CDDL HEADER, with the 16 * fields enclosed by brackets "[]" replaced with your own identifying 17 * information: Portions Copyright [yyyy] [name of copyright owner] 18 * 19 * CDDL HEADER END 20 */ 21 /* 22 * Copyright 2006 Sun Microsystems, Inc. All rights reserved. 23 * Use is subject to license terms. 24 */ 25 26 #pragma ident "%Z%%M% %I% %E% SMI" 27 28 /* 29 * Psycho+ specifics implementation: 30 * interrupt mapping register 31 * PBM configuration 32 * ECC and PBM error handling 33 * Iommu mapping handling 34 * Streaming Cache flushing 35 */ 36 37 #include <sys/types.h> 38 #include <sys/kmem.h> 39 #include <sys/sysmacros.h> 40 #include <sys/async.h> 41 #include <sys/ivintr.h> 42 #include <sys/systm.h> 43 #include <sys/intreg.h> /* UPAID_TO_IGN() */ 44 #include <sys/intr.h> 45 #include <sys/sunddi.h> 46 #include <sys/sunndi.h> 47 #include <sys/machsystm.h> 48 #include <sys/fm/util.h> 49 #include <sys/ddi_impldefs.h> 50 #include <sys/iommutsb.h> 51 #include <sys/spl.h> 52 #include <sys/fm/util.h> 53 #include <sys/fm/protocol.h> 54 #include <sys/fm/io/pci.h> 55 #include <sys/fm/io/sun4upci.h> 56 #include <sys/pci/pci_obj.h> 57 #include <sys/pci/pcipsy.h> 58 59 #ifdef _STARFIRE 60 #include <sys/starfire.h> 61 #endif /* _STARFIRE */ 62 63 static uint32_t pci_identity_init(pci_t *pci_p); 64 static int pci_intr_setup(pci_t *pci_p); 65 static void pci_pbm_errstate_get(pci_t *pci_p, pbm_errstate_t *pbm_err_p); 66 67 static pci_ksinfo_t *pci_name_kstat; 68 69 /*LINTLIBRARY*/ 70 /* called by pci_attach() DDI_ATTACH to initialize pci objects */ 71 int 72 pci_obj_setup(pci_t *pci_p) 73 { 74 pci_common_t *cmn_p; 75 int ret; 76 77 mutex_enter(&pci_global_mutex); 78 cmn_p = get_pci_common_soft_state(pci_p->pci_id); 79 if (cmn_p == NULL) { 80 uint_t id = pci_p->pci_id; 81 if (alloc_pci_common_soft_state(id) != DDI_SUCCESS) { 82 mutex_exit(&pci_global_mutex); 83 return (DDI_FAILURE); 84 } 85 cmn_p = get_pci_common_soft_state(id); 86 cmn_p->pci_common_id = id; 87 } 88 89 ASSERT((pci_p->pci_side == 0) || (pci_p->pci_side == 1)); 90 if (cmn_p->pci_p[pci_p->pci_side]) { 91 /* second side attach */ 92 pci_p->pci_side = PCI_OTHER_SIDE(pci_p->pci_side); 93 ASSERT(cmn_p->pci_p[pci_p->pci_side] == NULL); 94 } 95 96 cmn_p->pci_p[pci_p->pci_side] = pci_p; 97 pci_p->pci_common_p = cmn_p; 98 99 if (cmn_p->pci_common_refcnt == 0) { 100 /* Perform allocation first to avoid delicate unwinding. */ 101 if (pci_alloc_tsb(pci_p) != DDI_SUCCESS) { 102 cmn_p->pci_p[pci_p->pci_side] = NULL; 103 pci_p->pci_common_p = NULL; 104 free_pci_common_soft_state(cmn_p->pci_common_id); 105 mutex_exit(&pci_global_mutex); 106 return (DDI_FAILURE); 107 } 108 cmn_p->pci_common_tsb_cookie = pci_p->pci_tsb_cookie; 109 cmn_p->pci_chip_id = pci_identity_init(pci_p); 110 111 ib_create(pci_p); 112 cmn_p->pci_common_ib_p = pci_p->pci_ib_p; 113 114 cb_create(pci_p); 115 cmn_p->pci_common_cb_p = pci_p->pci_cb_p; 116 117 iommu_create(pci_p); 118 cmn_p->pci_common_iommu_p = pci_p->pci_iommu_p; 119 120 ecc_create(pci_p); 121 cmn_p->pci_common_ecc_p = pci_p->pci_ecc_p; 122 } else { 123 ASSERT(cmn_p->pci_common_refcnt == 1); 124 125 pci_p->pci_tsb_cookie = cmn_p->pci_common_tsb_cookie; 126 pci_p->pci_ib_p = cmn_p->pci_common_ib_p; 127 pci_p->pci_cb_p = cmn_p->pci_common_cb_p; 128 pci_p->pci_iommu_p = cmn_p->pci_common_iommu_p; 129 pci_p->pci_ecc_p = cmn_p->pci_common_ecc_p; 130 } 131 132 pbm_create(pci_p); 133 sc_create(pci_p); 134 135 pci_fm_create(pci_p); 136 137 if ((ret = pci_intr_setup(pci_p)) != DDI_SUCCESS) 138 goto done; 139 if (CHIP_TYPE(pci_p) == PCI_CHIP_PSYCHO) 140 pci_kstat_create(pci_p); 141 142 cmn_p->pci_common_attachcnt++; 143 cmn_p->pci_common_refcnt++; 144 done: 145 mutex_exit(&pci_global_mutex); 146 if (ret != DDI_SUCCESS) 147 cmn_err(CE_NOTE, "Interrupt register failure, returning 0x%x\n", 148 ret); 149 return (ret); 150 } 151 152 /* called by pci_detach() DDI_DETACH to destroy pci objects */ 153 void 154 pci_obj_destroy(pci_t *pci_p) 155 { 156 pci_common_t *cmn_p; 157 158 mutex_enter(&pci_global_mutex); 159 160 cmn_p = pci_p->pci_common_p; 161 cmn_p->pci_common_refcnt--; 162 cmn_p->pci_common_attachcnt--; 163 164 pci_kstat_destroy(pci_p); 165 166 sc_destroy(pci_p); 167 pbm_destroy(pci_p); 168 pci_fm_destroy(pci_p); 169 170 if (cmn_p->pci_common_refcnt != 0) { 171 cmn_p->pci_p[pci_p->pci_side] = NULL; 172 mutex_exit(&pci_global_mutex); 173 return; 174 } 175 176 ecc_destroy(pci_p); 177 iommu_destroy(pci_p); 178 cb_destroy(pci_p); 179 ib_destroy(pci_p); 180 181 free_pci_common_soft_state(cmn_p->pci_common_id); 182 pci_intr_teardown(pci_p); 183 mutex_exit(&pci_global_mutex); 184 } 185 186 /* called by pci_attach() DDI_RESUME to (re)initialize pci objects */ 187 void 188 pci_obj_resume(pci_t *pci_p) 189 { 190 pci_common_t *cmn_p = pci_p->pci_common_p; 191 192 mutex_enter(&pci_global_mutex); 193 194 if (cmn_p->pci_common_attachcnt == 0) { 195 ib_configure(pci_p->pci_ib_p); 196 iommu_configure(pci_p->pci_iommu_p); 197 ecc_configure(pci_p); 198 ib_resume(pci_p->pci_ib_p); 199 } 200 201 pbm_configure(pci_p->pci_pbm_p); 202 sc_configure(pci_p->pci_sc_p); 203 204 if (cmn_p->pci_common_attachcnt == 0) 205 cb_resume(pci_p->pci_cb_p); 206 207 pbm_resume(pci_p->pci_pbm_p); 208 209 cmn_p->pci_common_attachcnt++; 210 mutex_exit(&pci_global_mutex); 211 } 212 213 /* called by pci_detach() DDI_SUSPEND to suspend pci objects */ 214 void 215 pci_obj_suspend(pci_t *pci_p) 216 { 217 mutex_enter(&pci_global_mutex); 218 219 pbm_suspend(pci_p->pci_pbm_p); 220 if (!--pci_p->pci_common_p->pci_common_attachcnt) { 221 ib_suspend(pci_p->pci_ib_p); 222 cb_suspend(pci_p->pci_cb_p); 223 } 224 225 mutex_exit(&pci_global_mutex); 226 } 227 228 static uint32_t javelin_prom_fix[] = {0xfff800, 0, 0, 0x3f}; 229 static int 230 pci_intr_setup(pci_t *pci_p) 231 { 232 extern char *platform; 233 dev_info_t *dip = pci_p->pci_dip; 234 pbm_t *pbm_p = pci_p->pci_pbm_p; 235 cb_t *cb_p = pci_p->pci_cb_p; 236 int i, no_of_intrs; 237 238 /* 239 * This is a hack to fix a broken imap entry in the javelin PROM. 240 * see bugid 4226603 241 */ 242 if (strcmp((const char *)&platform, "SUNW,Ultra-250") == 0) 243 (void) ddi_prop_create(DDI_DEV_T_NONE, dip, DDI_PROP_CANSLEEP, 244 "interrupt-map-mask", (caddr_t)javelin_prom_fix, 245 sizeof (javelin_prom_fix)); 246 247 /* 248 * Get the interrupts property. 249 */ 250 if (ddi_getlongprop(DDI_DEV_T_ANY, dip, DDI_PROP_DONTPASS, 251 "interrupts", (caddr_t)&pci_p->pci_inos, 252 &pci_p->pci_inos_len) != DDI_SUCCESS) 253 cmn_err(CE_PANIC, "%s%d: no interrupts property\n", 254 ddi_driver_name(dip), ddi_get_instance(dip)); 255 256 /* 257 * figure out number of interrupts in the "interrupts" property 258 * and convert them all into ino. 259 */ 260 i = ddi_getprop(DDI_DEV_T_ANY, dip, 0, "#interrupt-cells", 1); 261 i = CELLS_1275_TO_BYTES(i); 262 no_of_intrs = pci_p->pci_inos_len / i; 263 for (i = 0; i < no_of_intrs; i++) 264 pci_p->pci_inos[i] = IB_MONDO_TO_INO(pci_p->pci_inos[i]); 265 266 if (pci_p->pci_common_p->pci_common_refcnt == 0) { 267 cb_p->cb_no_of_inos = no_of_intrs; 268 if (i = cb_register_intr(pci_p)) 269 goto teardown; 270 if (i = ecc_register_intr(pci_p)) 271 goto teardown; 272 273 intr_dist_add(cb_intr_dist, cb_p); 274 cb_enable_intr(pci_p); 275 ecc_enable_intr(pci_p); 276 } 277 278 if (i = pbm_register_intr(pbm_p)) { 279 if (pci_p->pci_common_p->pci_common_refcnt == 0) 280 intr_dist_rem(cb_intr_dist, cb_p); 281 goto teardown; 282 } 283 intr_dist_add(pbm_intr_dist, pbm_p); 284 ib_intr_enable(pci_p, pci_p->pci_inos[CBNINTR_PBM]); 285 286 if (pci_p->pci_common_p->pci_common_refcnt == 0) 287 intr_dist_add_weighted(ib_intr_dist_all, pci_p->pci_ib_p); 288 return (DDI_SUCCESS); 289 teardown: 290 pci_intr_teardown(pci_p); 291 return (i); 292 } 293 294 /* 295 * pci_fix_ranges - fixes the config space entry of the "ranges" 296 * property on psycho+ platforms 297 */ 298 void 299 pci_fix_ranges(pci_ranges_t *rng_p, int rng_entries) 300 { 301 int i; 302 for (i = 0; i < rng_entries; i++, rng_p++) 303 if ((rng_p->child_high & PCI_REG_ADDR_M) == PCI_ADDR_CONFIG) 304 rng_p->parent_low |= rng_p->child_high; 305 } 306 307 /* 308 * map_pci_registers 309 * 310 * This function is called from the attach routine to map the registers 311 * accessed by this driver. 312 * 313 * used by: pci_attach() 314 * 315 * return value: DDI_FAILURE on failure 316 */ 317 int 318 map_pci_registers(pci_t *pci_p, dev_info_t *dip) 319 { 320 ddi_device_acc_attr_t attr; 321 322 attr.devacc_attr_version = DDI_DEVICE_ATTR_V0; 323 attr.devacc_attr_dataorder = DDI_STRICTORDER_ACC; 324 325 attr.devacc_attr_endian_flags = DDI_NEVERSWAP_ACC; 326 if (ddi_regs_map_setup(dip, 0, &pci_p->pci_address[0], 0, 0, 327 &attr, &pci_p->pci_ac[0]) != DDI_SUCCESS) { 328 cmn_err(CE_WARN, "%s%d: unable to map reg entry 0\n", 329 ddi_driver_name(dip), ddi_get_instance(dip)); 330 return (DDI_FAILURE); 331 } 332 /* 333 * if we don't have streaming buffer, then we don't have 334 * pci_address[2]. 335 */ 336 if (pci_stream_buf_exists && 337 ddi_regs_map_setup(dip, 2, &pci_p->pci_address[2], 0, 0, 338 &attr, &pci_p->pci_ac[2]) != DDI_SUCCESS) { 339 cmn_err(CE_WARN, "%s%d: unable to map reg entry 2\n", 340 ddi_driver_name(dip), ddi_get_instance(dip)); 341 ddi_regs_map_free(&pci_p->pci_ac[0]); 342 return (DDI_FAILURE); 343 } 344 345 /* 346 * The second register set contains the bridge's configuration 347 * header. This header is at the very beginning of the bridge's 348 * configuration space. This space has litte-endian byte order. 349 */ 350 attr.devacc_attr_endian_flags = DDI_STRUCTURE_LE_ACC; 351 if (ddi_regs_map_setup(dip, 1, &pci_p->pci_address[1], 0, 352 PCI_CONF_HDR_SIZE, &attr, &pci_p->pci_ac[1]) != DDI_SUCCESS) { 353 354 cmn_err(CE_WARN, "%s%d: unable to map reg entry 1\n", 355 ddi_driver_name(dip), ddi_get_instance(dip)); 356 ddi_regs_map_free(&pci_p->pci_ac[0]); 357 if (pci_stream_buf_exists) 358 ddi_regs_map_free(&pci_p->pci_ac[2]); 359 return (DDI_FAILURE); 360 } 361 DEBUG3(DBG_ATTACH, dip, "address (%p,%p,%p)\n", 362 pci_p->pci_address[0], pci_p->pci_address[1], 363 pci_p->pci_address[2]); 364 365 return (DDI_SUCCESS); 366 } 367 368 /* 369 * unmap_pci_registers: 370 * 371 * This routine unmap the registers mapped by map_pci_registers. 372 * 373 * used by: pci_detach() 374 * 375 * return value: none 376 */ 377 void 378 unmap_pci_registers(pci_t *pci_p) 379 { 380 ddi_regs_map_free(&pci_p->pci_ac[0]); 381 ddi_regs_map_free(&pci_p->pci_ac[1]); 382 if (pci_stream_buf_exists) 383 ddi_regs_map_free(&pci_p->pci_ac[2]); 384 } 385 386 /* 387 * These convenience wrappers relies on map_pci_registers() to setup 388 * pci_address[0-2] correctly at first. 389 */ 390 /* The psycho+ reg base is at 1fe.0000.0000 */ 391 static uintptr_t 392 get_reg_base(pci_t *pci_p) 393 { 394 return ((uintptr_t)pci_p->pci_address[pci_stream_buf_exists ? 2 : 0]); 395 } 396 397 /* The psycho+ config reg base is always the 2nd reg entry */ 398 static uintptr_t 399 get_config_reg_base(pci_t *pci_p) 400 { 401 return ((uintptr_t)(pci_p->pci_address[1])); 402 } 403 404 uint64_t 405 ib_get_map_reg(ib_mondo_t mondo, uint32_t cpu_id) 406 { 407 return ((mondo) | (cpu_id << COMMON_INTR_MAP_REG_TID_SHIFT) | 408 COMMON_INTR_MAP_REG_VALID); 409 410 } 411 412 uint32_t 413 ib_map_reg_get_cpu(volatile uint64_t reg) 414 { 415 return ((reg & COMMON_INTR_MAP_REG_TID) >> 416 COMMON_INTR_MAP_REG_TID_SHIFT); 417 } 418 419 uint64_t * 420 ib_intr_map_reg_addr(ib_t *ib_p, ib_ino_t ino) 421 { 422 uint64_t *addr; 423 424 if (ino & 0x20) 425 addr = (uint64_t *)(ib_p->ib_obio_intr_map_regs + 426 (((uint_t)ino & 0x1f) << 3)); 427 else 428 addr = (uint64_t *)(ib_p->ib_slot_intr_map_regs + 429 (((uint_t)ino & 0x3c) << 1)); 430 return (addr); 431 } 432 433 uint64_t * 434 ib_clear_intr_reg_addr(ib_t *ib_p, ib_ino_t ino) 435 { 436 uint64_t *addr; 437 438 if (ino & 0x20) 439 addr = (uint64_t *)(ib_p->ib_obio_clear_intr_regs + 440 (((uint_t)ino & 0x1f) << 3)); 441 else 442 addr = (uint64_t *)(ib_p->ib_slot_clear_intr_regs + 443 (((uint_t)ino & 0x1f) << 3)); 444 return (addr); 445 } 446 447 /* 448 * psycho have one mapping register per slot 449 */ 450 void 451 ib_ino_map_reg_share(ib_t *ib_p, ib_ino_t ino, ib_ino_info_t *ino_p) 452 { 453 if (!IB_IS_OBIO_INO(ino)) { 454 ASSERT(ino_p->ino_slot_no < 8); 455 ib_p->ib_map_reg_counters[ino_p->ino_slot_no]++; 456 } 457 } 458 459 /* 460 * return true if the ino shares mapping register with other interrupts 461 * of the same slot, or is still shared by other On-board devices. 462 */ 463 int 464 ib_ino_map_reg_unshare(ib_t *ib_p, ib_ino_t ino, ib_ino_info_t *ino_p) 465 { 466 ASSERT(IB_IS_OBIO_INO(ino) || ino_p->ino_slot_no < 8); 467 468 if (IB_IS_OBIO_INO(ino)) 469 return (ino_p->ino_ih_size); 470 else 471 return (--ib_p->ib_map_reg_counters[ino_p->ino_slot_no]); 472 } 473 474 /*ARGSUSED*/ 475 void 476 pci_pbm_intr_dist(pbm_t *pbm_p) 477 { 478 } 479 480 uintptr_t 481 pci_ib_setup(ib_t *ib_p) 482 { 483 pci_t *pci_p = ib_p->ib_pci_p; 484 uintptr_t a = get_reg_base(pci_p); 485 486 ib_p->ib_ign = PCI_ID_TO_IGN(pci_p->pci_id); 487 ib_p->ib_max_ino = PSYCHO_MAX_INO; 488 ib_p->ib_slot_intr_map_regs = a + PSYCHO_IB_SLOT_INTR_MAP_REG_OFFSET; 489 ib_p->ib_obio_intr_map_regs = a + PSYCHO_IB_OBIO_INTR_MAP_REG_OFFSET; 490 ib_p->ib_obio_clear_intr_regs = 491 a + PSYCHO_IB_OBIO_CLEAR_INTR_REG_OFFSET; 492 return (a); 493 } 494 495 uint32_t 496 pci_xlate_intr(dev_info_t *dip, dev_info_t *rdip, ib_t *ib_p, uint32_t intr) 497 { 498 int32_t len; 499 dev_info_t *cdip; 500 pci_regspec_t *pci_rp; 501 uint32_t bus, dev, phys_hi; 502 503 if ((intr > PCI_INTD) || (intr < PCI_INTA)) 504 goto done; 505 if (ddi_prop_exists(DDI_DEV_T_ANY, rdip, NULL, "interrupt-map")) 506 goto done; 507 /* 508 * Hack for pre 1275 imap machines e.g. quark & tazmo 509 * We need to turn any PCI interrupts into ino interrupts. machines 510 * supporting imap will have this done in the map. 511 */ 512 cdip = get_my_childs_dip(dip, rdip); 513 if (ddi_getlongprop(DDI_DEV_T_ANY, cdip, DDI_PROP_DONTPASS, "reg", 514 (caddr_t)&pci_rp, &len) != DDI_SUCCESS) 515 return (0); 516 phys_hi = pci_rp->pci_phys_hi; 517 kmem_free(pci_rp, len); 518 519 bus = PCI_REG_BUS_G(phys_hi); 520 dev = PCI_REG_DEV_G(phys_hi); 521 522 /* 523 * The ino for a given device id is derived as 0BSSNN where 524 * 525 * B = 0 for bus A, 1 for bus B 526 * SS = dev - 1 for bus A, dev - 2 for bus B 527 * NN = 00 for INTA#, 01 for INTB#, 10 for INTC#, 11 for INTD# 528 * 529 * if pci bus number > 0x80, then devices are located on the A side(66) 530 */ 531 DEBUG3(DBG_IB, dip, "pci_xlate_intr: bus=%x, dev=%x, intr=%x\n", 532 bus, dev, intr); 533 intr--; 534 intr |= (bus & 0x80) ? ((dev - 1) << 2) : (0x10 | ((dev - 2) << 2)); 535 536 DEBUG1(DBG_IB, dip, "pci_xlate_intr: done ino=%x\n", intr); 537 done: 538 return (IB_INO_TO_MONDO(ib_p, intr)); 539 } 540 541 /* 542 * Return the cpuid to to be used for an ino. Psycho has special slot-cpu 543 * constraints on cpu assignment: 544 * 545 * On multi-function pci cards, functions have separate devinfo nodes and 546 * interrupts. Some pci support hardware, such as the psycho/pcipsy chip, 547 * control interrupt-to-cpu binding on a per pci-slot basis instead of per 548 * function. For hardware like this, if an interrupt for one function has 549 * already been directed to a particular cpu, we can't choose a different 550 * cpu for another function implemented in the same pci-slot - if we did 551 * we would be redirecting the first function too (which causes problems 552 * for consistent interrupt distribution). 553 * 554 * This function determines if there is already an established slot-oriented 555 * interrupt-to-cpu binding established, if there is then it returns that 556 * cpu. Otherwise a new cpu is selected by intr_dist_cpuid(). 557 * 558 * The devinfo node we are trying to associate a cpu with is 559 * ino_p->ino_ih_head->ih_dip. 560 */ 561 uint32_t 562 pci_intr_dist_cpuid(ib_t *ib_p, ib_ino_info_t *ino_p) 563 { 564 dev_info_t *rdip = ino_p->ino_ih_head->ih_dip; 565 dev_info_t *prdip = ddi_get_parent(rdip); 566 ib_ino_info_t *sino_p; 567 dev_info_t *sdip; 568 dev_info_t *psdip; 569 char *buf1 = NULL, *buf2 = NULL; 570 char *s1, *s2, *s3; 571 int l2; 572 int cpu_id; 573 574 /* must be psycho driver parent (not ebus) */ 575 if (strcmp(ddi_driver_name(prdip), "pcipsy") != 0) 576 goto newcpu; 577 578 /* 579 * From PCI 1275 binding: 2.2.1.3 Unit Address representation: 580 * Since the "unit-number" is the address that appears in on Open 581 * Firmware 'device path', it follows that only the DD and DD,FF 582 * forms of the text representation can appear in a 'device path'. 583 * 584 * The rdip unit address is of the form "DD[,FF]". Define two 585 * unit address strings that represent same-slot use: "DD" and "DD,". 586 * The first compare uses strcmp, the second uses strncmp. 587 */ 588 s1 = ddi_get_name_addr(rdip); 589 if (s1 == NULL) 590 goto newcpu; 591 592 buf1 = kmem_alloc(MAXNAMELEN, KM_SLEEP); /* strcmp */ 593 buf2 = kmem_alloc(MAXNAMELEN, KM_SLEEP); /* strncmp */ 594 s1 = strcpy(buf1, s1); 595 s2 = strcpy(buf2, s1); 596 597 s1 = strrchr(s1, ','); 598 if (s1) { 599 *s1 = '\0'; /* have "DD,FF" */ 600 s1 = buf1; /* search via strcmp "DD" */ 601 602 s2 = strrchr(s2, ','); 603 *(s2 + 1) = '\0'; 604 s2 = buf2; 605 l2 = strlen(s2); /* search via strncmp "DD," */ 606 } else { 607 (void) strcat(s2, ","); /* have "DD" */ 608 l2 = strlen(s2); /* search via strncmp "DD," */ 609 } 610 611 /* 612 * Search the established ino list for devinfo nodes bound 613 * to an ino that matches one of the slot use strings. 614 */ 615 ASSERT(MUTEX_HELD(&ib_p->ib_ino_lst_mutex)); 616 for (sino_p = ib_p->ib_ino_lst; sino_p; sino_p = sino_p->ino_next) { 617 /* skip self and non-established */ 618 if ((sino_p == ino_p) || (sino_p->ino_established == 0)) 619 continue; 620 621 /* skip non-siblings */ 622 sdip = sino_p->ino_ih_head->ih_dip; 623 psdip = ddi_get_parent(sdip); 624 if (psdip != prdip) 625 continue; 626 627 /* must be psycho driver parent (not ebus) */ 628 if (strcmp(ddi_driver_name(psdip), "pcipsy") != 0) 629 continue; 630 631 s3 = ddi_get_name_addr(sdip); 632 if ((s1 && (strcmp(s1, s3) == 0)) || 633 (strncmp(s2, s3, l2) == 0)) { 634 extern int intr_dist_debug; 635 636 if (intr_dist_debug) 637 cmn_err(CE_CONT, "intr_dist: " 638 "pcipsy`pci_intr_dist_cpuid " 639 "%s#%d %s: cpu %d established " 640 "by %s#%d %s\n", ddi_driver_name(rdip), 641 ddi_get_instance(rdip), 642 ddi_deviname(rdip, buf1), sino_p->ino_cpuid, 643 ddi_driver_name(sdip), 644 ddi_get_instance(sdip), 645 ddi_deviname(sdip, buf2)); 646 break; 647 } 648 } 649 650 /* If a slot use match is found then use established cpu */ 651 if (sino_p) { 652 cpu_id = sino_p->ino_cpuid; /* target established cpu */ 653 goto out; 654 } 655 656 newcpu: cpu_id = intr_dist_cpuid(); /* target new cpu */ 657 658 out: if (buf1) 659 kmem_free(buf1, MAXNAMELEN); 660 if (buf2) 661 kmem_free(buf2, MAXNAMELEN); 662 return (cpu_id); 663 } 664 665 666 /*ARGSUSED*/ 667 uint_t 668 cb_thermal_intr(caddr_t a) 669 { 670 cmn_err(CE_WARN, "pci: Thermal warning detected!\n"); 671 if (pci_thermal_intr_fatal) { 672 do_shutdown(); 673 674 /* 675 * In case do_shutdown() fails to halt the system. 676 */ 677 (void) timeout((void(*)(void *))power_down, NULL, 678 thermal_powerdown_delay * hz); 679 } 680 return (DDI_INTR_CLAIMED); 681 } 682 683 void 684 pci_cb_teardown(pci_t *pci_p) 685 { 686 cb_t *cb_p = pci_p->pci_cb_p; 687 uint32_t mondo; 688 689 if (pci_p->pci_thermal_interrupt != -1) { 690 mondo = ((pci_p->pci_cb_p->cb_ign << PCI_INO_BITS) | 691 pci_p->pci_inos[CBNINTR_THERMAL]); 692 mondo = CB_MONDO_TO_XMONDO(pci_p->pci_cb_p, mondo); 693 694 cb_disable_nintr(cb_p, CBNINTR_THERMAL, IB_INTR_WAIT); 695 rem_ivintr(mondo, NULL); 696 } 697 #ifdef _STARFIRE 698 pc_ittrans_uninit(cb_p->cb_ittrans_cookie); 699 #endif /* _STARFIRE */ 700 } 701 702 int 703 cb_register_intr(pci_t *pci_p) 704 { 705 uint32_t mondo; 706 707 if (pci_p->pci_thermal_interrupt == -1) 708 return (DDI_SUCCESS); 709 710 mondo = ((pci_p->pci_cb_p->cb_ign << PCI_INO_BITS) | 711 pci_p->pci_inos[CBNINTR_THERMAL]); 712 mondo = CB_MONDO_TO_XMONDO(pci_p->pci_cb_p, mondo); 713 714 VERIFY(add_ivintr(mondo, pci_pil[CBNINTR_THERMAL], 715 cb_thermal_intr, (caddr_t)pci_p->pci_cb_p, NULL) == 0); 716 717 return (PCI_ATTACH_RETCODE(PCI_CB_OBJ, PCI_OBJ_INTR_ADD, DDI_SUCCESS)); 718 } 719 720 void 721 cb_enable_intr(pci_t *pci_p) 722 { 723 if (pci_p->pci_thermal_interrupt != -1) 724 cb_enable_nintr(pci_p, CBNINTR_THERMAL); 725 } 726 727 uint64_t 728 cb_ino_to_map_pa(cb_t *cb_p, ib_ino_t ino) 729 { 730 return (cb_p->cb_map_pa + ((ino & 0x1f) << 3)); 731 } 732 733 uint64_t 734 cb_ino_to_clr_pa(cb_t *cb_p, ib_ino_t ino) 735 { 736 return (cb_p->cb_clr_pa + ((ino & 0x1f) << 3)); 737 } 738 739 /* 740 * allow removal of exported/shared thermal interrupt 741 */ 742 int 743 cb_remove_xintr(pci_t *pci_p, dev_info_t *dip, dev_info_t *rdip, 744 ib_ino_t ino, ib_mondo_t mondo) 745 { 746 if (ino != pci_p->pci_inos[CBNINTR_THERMAL]) 747 return (DDI_FAILURE); 748 749 cb_disable_nintr(pci_p->pci_cb_p, CBNINTR_THERMAL, IB_INTR_WAIT); 750 rem_ivintr(mondo, NULL); 751 752 DEBUG1(DBG_R_INTX, dip, "remove xintr %x\n", ino); 753 return (DDI_SUCCESS); 754 } 755 756 int 757 pci_ecc_add_intr(pci_t *pci_p, int inum, ecc_intr_info_t *eii_p) 758 { 759 uint32_t mondo; 760 761 mondo = ((pci_p->pci_cb_p->cb_ign << PCI_INO_BITS) | 762 pci_p->pci_inos[inum]); 763 mondo = CB_MONDO_TO_XMONDO(pci_p->pci_cb_p, mondo); 764 765 VERIFY(add_ivintr(mondo, pci_pil[inum], ecc_intr, 766 (caddr_t)eii_p, NULL) == 0); 767 768 return (PCI_ATTACH_RETCODE(PCI_ECC_OBJ, PCI_OBJ_INTR_ADD, DDI_SUCCESS)); 769 } 770 771 void 772 pci_ecc_rem_intr(pci_t *pci_p, int inum, ecc_intr_info_t *eii_p) 773 { 774 uint32_t mondo; 775 776 mondo = ((pci_p->pci_cb_p->cb_ign << PCI_INO_BITS) | 777 pci_p->pci_inos[inum]); 778 mondo = CB_MONDO_TO_XMONDO(pci_p->pci_cb_p, mondo); 779 780 rem_ivintr(mondo, NULL); 781 } 782 783 static int pbm_has_pass_1_cheerio(pci_t *pci_p); 784 785 void 786 pbm_configure(pbm_t *pbm_p) 787 { 788 pci_t *pci_p = pbm_p->pbm_pci_p; 789 cb_t *cb_p = pci_p->pci_cb_p; 790 dev_info_t *dip = pci_p->pci_dip; 791 int instance = ddi_get_instance(dip); 792 uint32_t mask = 1 << instance; 793 uint64_t l; 794 uint16_t s = 0; 795 796 /* 797 * Workarounds for hardware bugs: 798 * 799 * bus parking 800 * 801 * Pass 2 psycho parts have a bug that requires bus 802 * parking to be disabled. 803 * 804 * Pass 1 cheerio parts have a bug which prevents them 805 * from working on a PBM with bus parking enabled. 806 * 807 * rerun disable 808 * 809 * Pass 1 and 2 psycho's require that the rerun's be 810 * enabled. 811 * 812 * retry limit 813 * 814 * For pass 1 and pass 2 psycho parts we disable the 815 * retry limit. This is because the limit of 16 seems 816 * too restrictive for devices that are children of pci 817 * to pci bridges. For pass 3 this limit will be 64. 818 * 819 * DMA write/PIO read sync 820 * 821 * For pass 2 psycho, the disable this feature. 822 */ 823 l = lddphysio(cb_p->cb_base_pa + PSYCHO_CB_CONTROL_STATUS_REG_OFFSET); 824 l &= PSYCHO_CB_CONTROL_STATUS_VER; 825 l >>= PSYCHO_CB_CONTROL_STATUS_VER_SHIFT; 826 827 DEBUG2(DBG_ATTACH, dip, "cb_create: ver=%d, mask=%x\n", l, mask); 828 pci_rerun_disable = (uint32_t)-1; 829 830 switch (l) { 831 case 0: 832 DEBUG0(DBG_ATTACH, dip, "cb_create: psycho pass 1\n"); 833 if (!pci_disable_pass1_workarounds) { 834 if (pbm_has_pass_1_cheerio(pci_p)) 835 pci_bus_parking_enable &= ~mask; 836 pci_rerun_disable &= ~mask; 837 pci_retry_disable |= mask; 838 } 839 break; 840 case 1: 841 if (!pci_disable_pass2_workarounds) { 842 pci_bus_parking_enable &= ~mask; 843 pci_rerun_disable &= ~mask; 844 pci_retry_disable |= mask; 845 pci_dwsync_disable |= mask; 846 } 847 break; 848 case 2: 849 if (!pci_disable_pass3_workarounds) { 850 pci_dwsync_disable |= mask; 851 if (pbm_has_pass_1_cheerio(pci_p)) 852 pci_bus_parking_enable &= ~mask; 853 } 854 break; 855 case 3: 856 if (!pci_disable_plus_workarounds) { 857 pci_dwsync_disable |= mask; 858 if (pbm_has_pass_1_cheerio(pci_p)) 859 pci_bus_parking_enable &= ~mask; 860 } 861 break; 862 default: 863 if (!pci_disable_default_workarounds) { 864 pci_dwsync_disable |= mask; 865 if (pbm_has_pass_1_cheerio(pci_p)) 866 pci_bus_parking_enable &= ~mask; 867 } 868 break; 869 } 870 871 /* 872 * Clear any PBM errors. 873 */ 874 l = (PSYCHO_PCI_AFSR_E_MASK << PSYCHO_PCI_AFSR_PE_SHIFT) | 875 (PSYCHO_PCI_AFSR_E_MASK << PSYCHO_PCI_AFSR_SE_SHIFT); 876 *pbm_p->pbm_async_flt_status_reg = l; 877 878 /* 879 * Clear error bits in configuration status register. 880 */ 881 s = PCI_STAT_PERROR | PCI_STAT_S_PERROR | 882 PCI_STAT_R_MAST_AB | PCI_STAT_R_TARG_AB | 883 PCI_STAT_S_TARG_AB | PCI_STAT_S_PERROR; 884 DEBUG1(DBG_ATTACH, dip, "pbm_configure: conf status reg=%x\n", s); 885 pbm_p->pbm_config_header->ch_status_reg = s; 886 DEBUG1(DBG_ATTACH, dip, "pbm_configure: conf status reg==%x\n", 887 pbm_p->pbm_config_header->ch_status_reg); 888 889 l = *pbm_p->pbm_ctrl_reg; /* save control register state */ 890 DEBUG1(DBG_ATTACH, dip, "pbm_configure: ctrl reg==%llx\n", l); 891 892 /* 893 * See if any SERR# signals are asserted. We'll clear them later. 894 */ 895 if (l & COMMON_PCI_CTRL_SERR) 896 cmn_err(CE_WARN, "%s%d: SERR asserted on pci bus\n", 897 ddi_driver_name(dip), instance); 898 899 /* 900 * Determine if PCI bus is running at 33 or 66 mhz. 901 */ 902 if (l & COMMON_PCI_CTRL_SPEED) 903 pbm_p->pbm_speed = PBM_SPEED_66MHZ; 904 else 905 pbm_p->pbm_speed = PBM_SPEED_33MHZ; 906 DEBUG1(DBG_ATTACH, dip, "pbm_configure: %d mhz\n", 907 pbm_p->pbm_speed == PBM_SPEED_66MHZ ? 66 : 33); 908 909 /* 910 * Enable error interrupts. 911 */ 912 if (pci_error_intr_enable & mask) 913 l |= PSYCHO_PCI_CTRL_ERR_INT_EN; 914 else 915 l &= ~PSYCHO_PCI_CTRL_ERR_INT_EN; 916 917 /* 918 * Disable pci streaming byte errors and error interrupts. 919 */ 920 pci_sbh_error_intr_enable &= ~mask; 921 l &= ~PSYCHO_PCI_CTRL_SBH_INT_EN; 922 923 /* 924 * Enable/disable bus parking. 925 */ 926 if ((pci_bus_parking_enable & mask) && 927 !ddi_prop_exists(DDI_DEV_T_ANY, dip, DDI_PROP_DONTPASS, 928 "no-bus-parking")) 929 l |= PSYCHO_PCI_CTRL_ARB_PARK; 930 else 931 l &= ~PSYCHO_PCI_CTRL_ARB_PARK; 932 933 /* 934 * Enable arbitration. 935 */ 936 if (pci_p->pci_side == B) 937 l = (l & ~PSYCHO_PCI_CTRL_ARB_EN_MASK) | pci_b_arb_enable; 938 else 939 l = (l & ~PSYCHO_PCI_CTRL_ARB_EN_MASK) | pci_a_arb_enable; 940 941 /* 942 * Make sure SERR is clear 943 */ 944 l |= COMMON_PCI_CTRL_SERR; 945 946 /* 947 * Make sure power management interrupt is disabled. 948 */ 949 l &= ~PSYCHO_PCI_CTRL_WAKEUP_EN; 950 951 #ifdef _STARFIRE 952 /* 953 * Hack to determine whether we do Starfire special handling 954 * For starfire, we simply program a constant odd-value 955 * (0x1D) in the MID field. 956 * 957 * Zero out the MID field before ORing. We leave the LSB of 958 * the MID field intact since we cannot have a zero (even) 959 * MID value. 960 */ 961 l &= 0xFF0FFFFFFFFFFFFFULL; 962 l |= 0x1DULL << 51; 963 964 /* 965 * Program in the Interrupt Group Number. Here we have to 966 * convert the starfire 7bit upaid into a 5bit value. 967 */ 968 l |= (uint64_t)STARFIRE_UPAID2HWIGN(pbm_p->pbm_pci_p->pci_id) 969 << COMMON_CB_CONTROL_STATUS_IGN_SHIFT; 970 #endif /* _STARFIRE */ 971 972 /* 973 * Now finally write the control register with the appropriate value. 974 */ 975 DEBUG1(DBG_ATTACH, dip, "pbm_configure: ctrl reg=%llx\n", l); 976 *pbm_p->pbm_ctrl_reg = l; 977 978 /* 979 * Allow the diag register to be set based upon variable that 980 * can be configured via /etc/system. 981 */ 982 l = *pbm_p->pbm_diag_reg; 983 DEBUG1(DBG_ATTACH, dip, "pbm_configure: PCI diag reg==%llx\n", l); 984 if (pci_retry_disable & mask) 985 l |= COMMON_PCI_DIAG_DIS_RETRY; 986 if (pci_retry_enable & mask) 987 l &= ~COMMON_PCI_DIAG_DIS_RETRY; 988 if (pci_intsync_disable & mask) 989 l |= COMMON_PCI_DIAG_DIS_INTSYNC; 990 else 991 l &= ~COMMON_PCI_DIAG_DIS_INTSYNC; 992 if (pci_dwsync_disable & mask) 993 l |= PSYCHO_PCI_DIAG_DIS_DWSYNC; 994 else 995 l &= ~PSYCHO_PCI_DIAG_DIS_DWSYNC; 996 DEBUG1(DBG_ATTACH, dip, "pbm_configure: PCI diag reg=%llx\n", l); 997 *pbm_p->pbm_diag_reg = l; 998 999 /* 1000 * Enable SERR# and parity reporting via command register. 1001 */ 1002 s = pci_perr_enable & mask ? PCI_COMM_PARITY_DETECT : 0; 1003 s |= pci_serr_enable & mask ? PCI_COMM_SERR_ENABLE : 0; 1004 DEBUG1(DBG_ATTACH, dip, "pbm_configure: conf command reg=%x\n", s); 1005 pbm_p->pbm_config_header->ch_command_reg = s; 1006 DEBUG1(DBG_ATTACH, dip, "pbm_configure: conf command reg==%x\n", 1007 pbm_p->pbm_config_header->ch_command_reg); 1008 1009 /* 1010 * The current versions of the obp are suppose to set the latency 1011 * timer register but do not. Bug 1234181 is open against this 1012 * problem. Until this bug is fixed we check to see if the obp 1013 * has attempted to set the latency timer register by checking 1014 * for the existence of a "latency-timer" property. 1015 */ 1016 if (pci_set_latency_timer_register) { 1017 DEBUG1(DBG_ATTACH, dip, 1018 "pbm_configure: set psycho latency timer to %x\n", 1019 pci_latency_timer); 1020 pbm_p->pbm_config_header->ch_latency_timer_reg = 1021 pci_latency_timer; 1022 } 1023 1024 (void) ndi_prop_update_int(DDI_DEV_T_ANY, dip, "latency-timer", 1025 (int)pbm_p->pbm_config_header->ch_latency_timer_reg); 1026 } 1027 1028 uint_t 1029 pbm_disable_pci_errors(pbm_t *pbm_p) 1030 { 1031 pci_t *pci_p = pbm_p->pbm_pci_p; 1032 ib_t *ib_p = pci_p->pci_ib_p; 1033 1034 /* 1035 * Disable error and streaming byte hole interrupts via the 1036 * PBM control register. 1037 */ 1038 *pbm_p->pbm_ctrl_reg &= 1039 ~(PSYCHO_PCI_CTRL_ERR_INT_EN | PSYCHO_PCI_CTRL_SBH_INT_EN); 1040 1041 /* 1042 * Disable error interrupts via the interrupt mapping register. 1043 */ 1044 ib_intr_disable(ib_p, pci_p->pci_inos[CBNINTR_PBM], IB_INTR_NOWAIT); 1045 return (BF_NONE); 1046 } 1047 1048 /*ARGSUSED*/ 1049 uint64_t 1050 pci_sc_configure(pci_t *pci_p) 1051 { 1052 return (0); 1053 } 1054 1055 /*ARGSUSED*/ 1056 void 1057 pci_pbm_dma_sync(pbm_t *pbm_p, ib_ino_t ino) 1058 { 1059 uint64_t pa = pbm_p->pbm_sync_reg_pa; 1060 if (pa) 1061 (void) lddphysio(pa); /* Load from Sync Register */ 1062 } 1063 1064 /*ARGSUSED*/ 1065 dvma_context_t 1066 pci_iommu_get_dvma_context(iommu_t *iommu_p, dvma_addr_t dvma_pg_index) 1067 { 1068 ASSERT(0); 1069 return (0); 1070 } 1071 1072 /*ARGSUSED*/ 1073 void 1074 pci_iommu_free_dvma_context(iommu_t *iommu_p, dvma_context_t ctx) 1075 { 1076 ASSERT(0); 1077 } 1078 1079 void 1080 pci_iommu_config(iommu_t *iommu_p, uint64_t iommu_ctl, uint64_t cfgpa) 1081 { 1082 volatile uint64_t *pbm_csr_p = (volatile uint64_t *) 1083 get_pbm_reg_base(iommu_p->iommu_pci_p); 1084 volatile uint64_t pbm_ctl = *pbm_csr_p; 1085 1086 volatile uint64_t *iommu_ctl_p = iommu_p->iommu_ctrl_reg; 1087 volatile uint64_t tsb_bar_val = iommu_p->iommu_tsb_paddr; 1088 volatile uint64_t *tsb_bar_p = iommu_p->iommu_tsb_base_addr_reg; 1089 1090 DEBUG2(DBG_ATTACH, iommu_p->iommu_pci_p->pci_dip, 1091 "\npci_iommu_config: pbm_csr_p=%016llx pbm_ctl=%016llx", 1092 pbm_csr_p, pbm_ctl); 1093 DEBUG2(DBG_ATTACH|DBG_CONT, iommu_p->iommu_pci_p->pci_dip, 1094 "\n\tiommu_ctl_p=%016llx iommu_ctl=%016llx", 1095 iommu_ctl_p, iommu_ctl); 1096 DEBUG2(DBG_ATTACH|DBG_CONT, iommu_p->iommu_pci_p->pci_dip, 1097 "\n\tcfgpa=%016llx tsb_bar_val=%016llx", cfgpa, tsb_bar_val); 1098 1099 if (!cfgpa) 1100 goto reprog; 1101 1102 /* disable PBM arbiters - turn off bits 0-7 */ 1103 *pbm_csr_p = (pbm_ctl >> 8) << 8; 1104 1105 /* make sure we own the bus by reading any child device config space */ 1106 (void) ldphysio(cfgpa); /* also flushes the prev write */ 1107 reprog: 1108 *tsb_bar_p = tsb_bar_val; 1109 *iommu_ctl_p = iommu_ctl; 1110 1111 *pbm_csr_p = pbm_ctl; /* re-enable bus arbitration */ 1112 pbm_ctl = *pbm_csr_p; /* flush all prev writes */ 1113 } 1114 1115 int 1116 pci_sc_ctx_inv(dev_info_t *dip, sc_t *sc_p, ddi_dma_impl_t *mp) 1117 { 1118 ASSERT(0); 1119 return (DDI_FAILURE); 1120 } 1121 1122 void 1123 pci_cb_setup(pci_t *pci_p) 1124 { 1125 uint64_t csr, csr_pa, pa; 1126 cb_t *cb_p = pci_p->pci_cb_p; 1127 1128 /* cb_p->cb_node_id = 0; */ 1129 cb_p->cb_ign = PCI_ID_TO_IGN(pci_p->pci_id); 1130 pa = (uint64_t)hat_getpfnum(kas.a_hat, pci_p->pci_address[0]); 1131 cb_p->cb_base_pa = pa = pa >> (32 - MMU_PAGESHIFT) << 32; 1132 cb_p->cb_map_pa = pa + PSYCHO_IB_OBIO_INTR_MAP_REG_OFFSET; 1133 cb_p->cb_clr_pa = pa + PSYCHO_IB_OBIO_CLEAR_INTR_REG_OFFSET; 1134 cb_p->cb_obsta_pa = pa + COMMON_IB_OBIO_INTR_STATE_DIAG_REG; 1135 1136 csr_pa = pa + PSYCHO_CB_CONTROL_STATUS_REG_OFFSET; 1137 csr = lddphysio(csr_pa); 1138 1139 /* 1140 * Clear any pending address parity errors. 1141 */ 1142 if (csr & COMMON_CB_CONTROL_STATUS_APERR) { 1143 csr |= COMMON_CB_CONTROL_STATUS_APERR; 1144 cmn_err(CE_WARN, "clearing UPA address parity error\n"); 1145 } 1146 csr |= COMMON_CB_CONTROL_STATUS_APCKEN; 1147 csr &= ~COMMON_CB_CONTROL_STATUS_IAP; 1148 stdphysio(csr_pa, csr); 1149 1150 #ifdef _STARFIRE 1151 /* Setup Starfire interrupt target translation */ 1152 pc_ittrans_init(pci_p->pci_id, &cb_p->cb_ittrans_cookie); 1153 #endif /* _STARFIRE */ 1154 1155 } 1156 1157 void 1158 pci_ecc_setup(ecc_t *ecc_p) 1159 { 1160 ecc_p->ecc_ue.ecc_errpndg_mask = 0; 1161 ecc_p->ecc_ue.ecc_offset_mask = PSYCHO_ECC_UE_AFSR_DW_OFFSET; 1162 ecc_p->ecc_ue.ecc_offset_shift = PSYCHO_ECC_UE_AFSR_DW_OFFSET_SHIFT; 1163 ecc_p->ecc_ue.ecc_size_log2 = 3; 1164 1165 ecc_p->ecc_ce.ecc_errpndg_mask = 0; 1166 ecc_p->ecc_ce.ecc_offset_mask = PSYCHO_ECC_CE_AFSR_DW_OFFSET; 1167 ecc_p->ecc_ce.ecc_offset_shift = PSYCHO_ECC_CE_AFSR_DW_OFFSET_SHIFT; 1168 ecc_p->ecc_ce.ecc_size_log2 = 3; 1169 } 1170 1171 /* 1172 * overwrite dvma end address (only on virtual-dma systems) 1173 * initialize tsb size 1174 * reset context bits 1175 * return: IOMMU CSR bank base address (VA) 1176 */ 1177 uintptr_t 1178 pci_iommu_setup(iommu_t *iommu_p) 1179 { 1180 pci_dvma_range_prop_t *dvma_prop; 1181 int dvma_prop_len; 1182 1183 pci_t *pci_p = iommu_p->iommu_pci_p; 1184 dev_info_t *dip = pci_p->pci_dip; 1185 uint_t tsb_size = iommu_tsb_cookie_to_size(pci_p->pci_tsb_cookie); 1186 uint_t tsb_size_prop; 1187 1188 if (ddi_getlongprop(DDI_DEV_T_ANY, dip, DDI_PROP_DONTPASS, 1189 "virtual-dma", (caddr_t)&dvma_prop, &dvma_prop_len) != 1190 DDI_PROP_SUCCESS) 1191 goto tsb_done; 1192 1193 if (dvma_prop_len != sizeof (pci_dvma_range_prop_t)) { 1194 cmn_err(CE_WARN, "%s%d: invalid virtual-dma property", 1195 ddi_driver_name(dip), ddi_get_instance(dip)); 1196 goto tsb_end; 1197 } 1198 iommu_p->iommu_dvma_end = dvma_prop->dvma_base + 1199 (dvma_prop->dvma_len - 1); 1200 tsb_size_prop = IOMMU_BTOP(dvma_prop->dvma_len) * sizeof (uint64_t); 1201 tsb_size = MIN(tsb_size_prop, tsb_size); 1202 tsb_end: 1203 kmem_free(dvma_prop, dvma_prop_len); 1204 tsb_done: 1205 iommu_p->iommu_tsb_size = iommu_tsb_size_encode(tsb_size); 1206 1207 if (CHIP_TYPE(pci_p) != PCI_CHIP_HUMMINGBIRD) 1208 pci_preserve_iommu_tsb = 0; 1209 1210 /* 1211 * Psycho has no context support. 1212 */ 1213 iommu_p->iommu_ctx_bitmap = NULL; 1214 iommu_p->iommu_flush_ctx_reg = NULL; 1215 pci_use_contexts = 0; 1216 pci_sc_use_contexts = 0; 1217 1218 /* 1219 * Determine the virtual address of the register block 1220 * containing the iommu control registers. 1221 */ 1222 return (get_reg_base(pci_p)); 1223 } 1224 1225 /*ARGSUSED*/ 1226 void 1227 pci_iommu_teardown(iommu_t *iommu_p) 1228 { 1229 } 1230 1231 /* The psycho+ PBM reg base is at 1fe.0000.2000 */ 1232 uintptr_t 1233 get_pbm_reg_base(pci_t *pci_p) 1234 { 1235 return ((uintptr_t)(pci_p->pci_address[0] + 1236 (pci_stream_buf_exists ? 0 : PSYCHO_PCI_PBM_REG_BASE))); 1237 } 1238 1239 void 1240 pci_post_uninit_child(pci_t *pci_p) 1241 { 1242 } 1243 1244 void 1245 pci_pbm_setup(pbm_t *pbm_p) 1246 { 1247 pci_t *pci_p = pbm_p->pbm_pci_p; 1248 1249 /* 1250 * Get the base virtual address for the PBM control block. 1251 */ 1252 uintptr_t a = get_pbm_reg_base(pci_p); 1253 1254 /* 1255 * Get the virtual address of the PCI configuration header. 1256 * This should be mapped little-endian. 1257 */ 1258 pbm_p->pbm_config_header = 1259 (config_header_t *)get_config_reg_base(pci_p); 1260 1261 /* 1262 * Get the virtual addresses for control, error and diag 1263 * registers. 1264 */ 1265 pbm_p->pbm_ctrl_reg = (uint64_t *)(a + PSYCHO_PCI_CTRL_REG_OFFSET); 1266 pbm_p->pbm_diag_reg = (uint64_t *)(a + PSYCHO_PCI_DIAG_REG_OFFSET); 1267 pbm_p->pbm_async_flt_status_reg = 1268 (uint64_t *)(a + PSYCHO_PCI_ASYNC_FLT_STATUS_REG_OFFSET); 1269 pbm_p->pbm_async_flt_addr_reg = 1270 (uint64_t *)(a + PSYCHO_PCI_ASYNC_FLT_ADDR_REG_OFFSET); 1271 1272 if (CHIP_TYPE(pci_p) >= PCI_CHIP_SABRE) 1273 pbm_p->pbm_sync_reg_pa = 1274 pci_p->pci_cb_p->cb_base_pa + DMA_WRITE_SYNC_REG; 1275 } 1276 1277 /*ARGSUSED*/ 1278 void 1279 pci_pbm_teardown(pbm_t *pbm_p) 1280 { 1281 } 1282 1283 void 1284 pci_sc_setup(sc_t *sc_p) 1285 { 1286 pci_t *pci_p = sc_p->sc_pci_p; 1287 1288 /* 1289 * Determine the virtual addresses of the streaming cache 1290 * control/status and flush registers. 1291 */ 1292 uintptr_t a = get_pbm_reg_base(pci_p); 1293 sc_p->sc_ctrl_reg = (uint64_t *)(a + PSYCHO_SC_CTRL_REG_OFFSET); 1294 sc_p->sc_invl_reg = (uint64_t *)(a + PSYCHO_SC_INVL_REG_OFFSET); 1295 sc_p->sc_sync_reg = (uint64_t *)(a + PSYCHO_SC_SYNC_REG_OFFSET); 1296 1297 /* 1298 * Determine the virtual addresses of the streaming cache 1299 * diagnostic access registers. 1300 */ 1301 a = get_reg_base(pci_p); 1302 if (pci_p->pci_bus_range.lo != 0) { 1303 sc_p->sc_data_diag_acc = (uint64_t *) 1304 (a + PSYCHO_SC_A_DATA_DIAG_OFFSET); 1305 sc_p->sc_tag_diag_acc = (uint64_t *) 1306 (a + PSYCHO_SC_A_TAG_DIAG_OFFSET); 1307 sc_p->sc_ltag_diag_acc = (uint64_t *) 1308 (a + PSYCHO_SC_A_LTAG_DIAG_OFFSET); 1309 } else { 1310 sc_p->sc_data_diag_acc = (uint64_t *) 1311 (a + PSYCHO_SC_B_DATA_DIAG_OFFSET); 1312 sc_p->sc_tag_diag_acc = (uint64_t *) 1313 (a + PSYCHO_SC_B_TAG_DIAG_OFFSET); 1314 sc_p->sc_ltag_diag_acc = (uint64_t *) 1315 (a + PSYCHO_SC_B_LTAG_DIAG_OFFSET); 1316 } 1317 } 1318 1319 int 1320 pci_get_numproxy(dev_info_t *dip) 1321 { 1322 return (ddi_prop_get_int(DDI_DEV_T_ANY, dip, DDI_PROP_DONTPASS, 1323 "#upa-interrupt-proxies", 1)); 1324 } 1325 1326 int 1327 pci_get_portid(dev_info_t *dip) 1328 { 1329 return (ddi_getprop(DDI_DEV_T_ANY, dip, DDI_PROP_DONTPASS, 1330 "upa-portid", -1)); 1331 } 1332 1333 /* 1334 * pbm_has_pass_1_cheerio 1335 * 1336 * 1337 * Given a PBM soft state pointer, this routine scans it child nodes 1338 * to see if one is a pass 1 cheerio. 1339 * 1340 * return value: 1 if pass 1 cheerio is found, 0 otherwise 1341 */ 1342 static int 1343 pbm_has_pass_1_cheerio(pci_t *pci_p) 1344 { 1345 dev_info_t *cdip; 1346 int found = 0; 1347 char *s; 1348 int rev; 1349 1350 cdip = ddi_get_child(pci_p->pci_dip); 1351 while (cdip != NULL && found == 0) { 1352 s = ddi_get_name(cdip); 1353 if (strcmp(s, "ebus") == 0 || strcmp(s, "pci108e,1000") == 0) { 1354 rev = 1355 ddi_getprop(DDI_DEV_T_ANY, cdip, DDI_PROP_DONTPASS, 1356 "revision-id", 0); 1357 if (rev == 0) 1358 found = 1; 1359 } 1360 cdip = ddi_get_next_sibling(cdip); 1361 } 1362 return (found); 1363 } 1364 1365 /* 1366 * Psycho Performance Events. 1367 */ 1368 pci_kev_mask_t 1369 psycho_pci_events[] = { 1370 {"dvma_stream_rd_a", 0x0}, {"dvma_stream_wr_a", 0x1}, 1371 {"dvma_const_rd_a", 0x2}, {"dvma_const_wr_a", 0x3}, 1372 {"dvma_stream_buf_mis_a", 0x4}, {"dvma_cycles_a", 0x5}, 1373 {"dvma_wd_xfr_a", 0x6}, {"pio_cycles_a", 0x7}, 1374 {"dvma_stream_rd_b", 0x8}, {"dvma_stream_wr_b", 0x9}, 1375 {"dvma_const_rd_b", 0xa}, {"dvma_const_wr_b", 0xb}, 1376 {"dvma_stream_buf_mis_b", 0xc}, {"dvma_cycles_b", 0xd}, 1377 {"dvma_wd_xfr_b", 0xe}, {"pio_cycles_b", 0xf}, 1378 {"dvma_tlb_misses", 0x10}, {"interrupts", 0x11}, 1379 {"upa_inter_nack", 0x12}, {"pio_reads", 0x13}, 1380 {"pio_writes", 0x14}, {"merge_buffer", 0x15}, 1381 {"dma_tbwalk_a", 0x16}, {"dma_stc_a", 0x17}, 1382 {"dma_tbwalk_b", 0x18}, {"dma_stc_b", 0x19}, 1383 {"clear_pic", 0x1f} 1384 }; 1385 1386 /* 1387 * Create the picN kstat's. 1388 */ 1389 void 1390 pci_kstat_init() 1391 { 1392 pci_name_kstat = (pci_ksinfo_t *)kmem_alloc(sizeof (pci_ksinfo_t), 1393 KM_NOSLEEP); 1394 1395 if (pci_name_kstat == NULL) { 1396 cmn_err(CE_WARN, "pcipsy : no space for kstat\n"); 1397 } else { 1398 pci_name_kstat->pic_no_evs = 1399 sizeof (psycho_pci_events) / sizeof (pci_kev_mask_t); 1400 pci_name_kstat->pic_shift[0] = PSYCHO_SHIFT_PIC0; 1401 pci_name_kstat->pic_shift[1] = PSYCHO_SHIFT_PIC1; 1402 pci_create_name_kstat("pcip", 1403 pci_name_kstat, psycho_pci_events); 1404 } 1405 } 1406 1407 /* 1408 * Called from _fini() 1409 */ 1410 void 1411 pci_kstat_fini() 1412 { 1413 if (pci_name_kstat != NULL) { 1414 pci_delete_name_kstat(pci_name_kstat); 1415 kmem_free(pci_name_kstat, sizeof (pci_ksinfo_t)); 1416 pci_name_kstat = NULL; 1417 } 1418 } 1419 1420 /* ARGSUSED */ 1421 void 1422 pci_add_pci_kstat(pci_t *pci_p) 1423 { 1424 } 1425 1426 /* ARGSUSED */ 1427 void 1428 pci_rem_pci_kstat(pci_t *pci_p) 1429 { 1430 } 1431 1432 /* 1433 * Create the performance 'counters' kstat. 1434 */ 1435 void 1436 pci_add_upstream_kstat(pci_t *pci_p) 1437 { 1438 pci_common_t *cmn_p = pci_p->pci_common_p; 1439 pci_cntr_pa_t *cntr_pa_p = &cmn_p->pci_cmn_uks_pa; 1440 uint64_t regbase = va_to_pa((void *)get_reg_base(pci_p)); 1441 1442 cntr_pa_p->pcr_pa = regbase + PSYCHO_PERF_PCR_OFFSET; 1443 cntr_pa_p->pic_pa = regbase + PSYCHO_PERF_PIC_OFFSET; 1444 cmn_p->pci_common_uksp = pci_create_cntr_kstat(pci_p, "pcip", 1445 NUM_OF_PICS, pci_cntr_kstat_pa_update, cntr_pa_p); 1446 } 1447 1448 /* 1449 * Extract the drivers binding name to identify which chip 1450 * we're binding to. Whenever a new bus bridge is created, the driver alias 1451 * entry should be added here to identify the device if needed. If a device 1452 * isn't added, the identity defaults to PCI_CHIP_UNIDENTIFIED. 1453 */ 1454 static uint32_t 1455 pci_identity_init(pci_t *pci_p) 1456 { 1457 dev_info_t *dip = pci_p->pci_dip; 1458 char *name = ddi_binding_name(dip); 1459 1460 if (strcmp(name, "pci108e,8000") == 0) 1461 return (CHIP_ID(PCI_CHIP_PSYCHO, 0x00, 0x00)); 1462 if (strcmp(name, "pci108e,a000") == 0) 1463 return (CHIP_ID(PCI_CHIP_SABRE, 0x00, 0x00)); 1464 if (strcmp(name, "pci108e,a001") == 0) 1465 return (CHIP_ID(PCI_CHIP_HUMMINGBIRD, 0x00, 0x00)); 1466 cmn_err(CE_CONT, "?%s%d:using default chip identity\n", 1467 ddi_driver_name(dip), ddi_get_instance(dip)); 1468 return (CHIP_ID(PCI_CHIP_PSYCHO, 0x00, 0x00)); 1469 } 1470 1471 /*ARGSUSED*/ 1472 void 1473 pci_post_init_child(pci_t *pci_p, dev_info_t *child) 1474 { 1475 } 1476 1477 /*ARGSUSED*/ 1478 int 1479 pci_pbm_add_intr(pci_t *pci_p) 1480 { 1481 return (DDI_SUCCESS); 1482 } 1483 1484 /*ARGSUSED*/ 1485 void 1486 pci_pbm_rem_intr(pci_t *pci_p) 1487 { 1488 } 1489 1490 /*ARGSUSED*/ 1491 void 1492 pci_pbm_suspend(pci_t *pci_p) 1493 { 1494 } 1495 1496 /*ARGSUSED*/ 1497 void 1498 pci_pbm_resume(pci_t *pci_p) 1499 { 1500 } 1501 1502 /* 1503 * pcipsy error handling 101: 1504 * 1505 * The various functions below are responsible for error handling. Given 1506 * a particular error, they must gather the appropriate state, report all 1507 * errors with correct payload, and attempt recovery where ever possible. 1508 * 1509 * Recovery in the context of this driver is being able notify a leaf device 1510 * of the failed transaction. This leaf device may either be the master or 1511 * target for this transaction and may have already received an error 1512 * notification via a PCI interrupt. Notification is done via DMA and access 1513 * handles. If we capture an address for the transaction then we can map it 1514 * to a handle(if the leaf device is fma-compliant) and fault the handle as 1515 * well as call the device driver registered callback. 1516 * 1517 * The hardware can either interrupt or trap upon detection of an error, in 1518 * some rare cases it also causes a fatal reset. 1519 * 1520 * pbm_error_intr() and ecc_intr() are responsible for PCI Block Module 1521 * errors(generic PCI + bridge specific) and ECC errors, respectively. They 1522 * are common between pcisch and pcipsy and therefore exist in pci_pbm.c and 1523 * pci_ecc.c. To support error handling certain chip specific handlers 1524 * must exist and they are defined below. 1525 * 1526 * cpu_deferred_error() and cpu_async_error(), handle the traps that may 1527 * have originated from IO space. They call into the registered IO callbacks 1528 * to report and handle errors that may have caused the trap. 1529 * 1530 * pci_pbm_err_handler() is called by pbm_error_intr() or pci_err_callback() 1531 * (generic fma callback for pcipsy/pcisch, pci_fm.c). pci_err_callback() is 1532 * called when the CPU has trapped because of a possible IO error(TO/BERR/UE). 1533 * It will call pci_pbm_err_handler() to report and handle all PCI/PBM/IOMMU 1534 * related errors which are detected by the chip. 1535 * 1536 * pci_pbm_err_handler() calls a generic interface pbm_afsr_report()(pci_pbm.c) 1537 * to report the pbm specific errors and attempt to map the failed address 1538 * (if captured) to a device instance. pbm_afsr_report() calls a chip specific 1539 * interface to interpret the afsr bits pci_pbm_classify()(pcisch.c/pcipsy.c). 1540 * 1541 * ecc_err_handler()(pci_ecc.c) also calls a chip specific interface to 1542 * interpret the afsr, pci_ecc_classify(). ecc_err_handler() also calls 1543 * pci_pbm_err_handler() and ndi_fm_handler_dispatch() to log any related 1544 * errors. 1545 * 1546 * To make sure that the trap code and the interrupt code are not going 1547 * to step on each others toes we have a per chip pci_fm_mutex. This also 1548 * makes it necessary for us to be cautious while we are at a high PIL, so 1549 * that we do not cause a subsequent trap that causes us to hang. 1550 * 1551 * The attempt to commonize code was meant to keep in line with the current 1552 * pci driver implementation and it was not meant to confuse. If you are 1553 * confused then don't worry, I was too. 1554 */ 1555 1556 /* 1557 * For Psycho, a UE is always fatal, except if it is a translation error on a 1558 * Darwin platform. We ignore these because they do not cause data corruption. 1559 */ 1560 int 1561 ecc_ue_is_fatal(struct async_flt *ecc) 1562 { 1563 return (((uint_t)(ecc->flt_stat >> SABRE_UE_AFSR_PDTE_SHIFT) & 1564 SABRE_UE_AFSR_E_PDTE) == 0); 1565 } 1566 1567 /* 1568 * pci_ecc_classify, called by ecc_handler to classify ecc errors 1569 * and determine if we should panic or not. 1570 * 1571 * Note that it is possible yet extremely rare for more than one 1572 * primary error bit to be set. We classify the ecc error based 1573 * on the first set bit that is found. 1574 */ 1575 void 1576 pci_ecc_classify(uint64_t err, ecc_errstate_t *ecc_err_p) 1577 { 1578 struct async_flt *ecc = &ecc_err_p->ecc_aflt; 1579 pci_common_t *cmn_p = ecc_err_p->ecc_ii_p.ecc_p->ecc_pci_cmn_p; 1580 1581 ASSERT(MUTEX_HELD(&cmn_p->pci_fm_mutex)); 1582 1583 ecc_err_p->ecc_bridge_type = PCI_BRIDGE_TYPE(cmn_p); 1584 /* 1585 * Get the parent bus id that caused the error. 1586 */ 1587 ecc_err_p->ecc_dev_id = (ecc_err_p->ecc_afsr & PSYCHO_ECC_UE_AFSR_ID) 1588 >> PSYCHO_ECC_UE_AFSR_ID_SHIFT; 1589 /* 1590 * Determine the doubleword offset of the error. 1591 */ 1592 ecc_err_p->ecc_dw_offset = (ecc_err_p->ecc_afsr & 1593 PSYCHO_ECC_UE_AFSR_DW_OFFSET) 1594 >> PSYCHO_ECC_UE_AFSR_DW_OFFSET_SHIFT; 1595 /* 1596 * Determine the primary error type. 1597 */ 1598 if (err & COMMON_ECC_UE_AFSR_E_PIO) { 1599 if (ecc_err_p->ecc_ii_p.ecc_type == CBNINTR_UE) { 1600 if (ecc_err_p->ecc_pri) { 1601 ecc->flt_erpt_class = PCI_ECC_PIO_UE; 1602 } else { 1603 ecc->flt_erpt_class = PCI_ECC_SEC_PIO_UE; 1604 } 1605 ecc->flt_panic = ecc_ue_is_fatal(&ecc_err_p->ecc_aflt); 1606 } else { 1607 ecc->flt_erpt_class = ecc_err_p->ecc_pri ? 1608 PCI_ECC_PIO_CE : PCI_ECC_SEC_PIO_CE; 1609 return; 1610 } 1611 } else if (err & COMMON_ECC_UE_AFSR_E_DRD) { 1612 if (ecc_err_p->ecc_ii_p.ecc_type == CBNINTR_UE) { 1613 if (ecc_err_p->ecc_pri) { 1614 ecc->flt_erpt_class = PCI_ECC_DRD_UE; 1615 } else { 1616 ecc->flt_erpt_class = PCI_ECC_SEC_DRD_UE; 1617 } 1618 ecc->flt_panic = ecc_ue_is_fatal(&ecc_err_p->ecc_aflt); 1619 } else { 1620 ecc->flt_erpt_class = ecc_err_p->ecc_pri ? 1621 PCI_ECC_DRD_CE : PCI_ECC_SEC_DRD_CE; 1622 return; 1623 } 1624 } else if (err & COMMON_ECC_UE_AFSR_E_DWR) { 1625 if (ecc_err_p->ecc_ii_p.ecc_type == CBNINTR_UE) { 1626 if (ecc_err_p->ecc_pri) { 1627 ecc->flt_erpt_class = PCI_ECC_DWR_UE; 1628 } else { 1629 ecc->flt_erpt_class = PCI_ECC_SEC_DWR_UE; 1630 } 1631 ecc->flt_panic = ecc_ue_is_fatal(&ecc_err_p->ecc_aflt); 1632 } else { 1633 ecc->flt_erpt_class = ecc_err_p->ecc_pri ? 1634 PCI_ECC_DWR_CE : PCI_ECC_SEC_DWR_CE; 1635 return; 1636 } 1637 } 1638 } 1639 1640 ushort_t 1641 pci_ecc_get_synd(uint64_t afsr) 1642 { 1643 return ((ushort_t)((afsr & PSYCHO_ECC_CE_AFSR_SYND) 1644 >> PSYCHO_ECC_CE_AFSR_SYND_SHIFT)); 1645 } 1646 1647 /* 1648 * pci_pbm_classify, called by pbm_afsr_report to classify piow afsr. 1649 */ 1650 int 1651 pci_pbm_classify(pbm_errstate_t *pbm_err_p) 1652 { 1653 uint32_t e; 1654 int nerr = 0; 1655 char **tmp_class; 1656 1657 if (pbm_err_p->pbm_pri) { 1658 tmp_class = &pbm_err_p->pbm_pci.pci_err_class; 1659 e = PBM_AFSR_TO_PRIERR(pbm_err_p->pbm_afsr); 1660 pbm_err_p->pbm_log = FM_LOG_PCI; 1661 } else { 1662 tmp_class = &pbm_err_p->pbm_err_class; 1663 e = PBM_AFSR_TO_SECERR(pbm_err_p->pbm_afsr); 1664 pbm_err_p->pbm_log = FM_LOG_PBM; 1665 } 1666 1667 if (e & PSYCHO_PCI_AFSR_E_MA) { 1668 *tmp_class = pbm_err_p->pbm_pri ? PCI_MA : PCI_SEC_MA; 1669 nerr++; 1670 } 1671 if (e & PSYCHO_PCI_AFSR_E_TA) { 1672 *tmp_class = pbm_err_p->pbm_pri ? PCI_REC_TA : PCI_SEC_REC_TA; 1673 nerr++; 1674 } 1675 if (e & PSYCHO_PCI_AFSR_E_RTRY) { 1676 pbm_err_p->pbm_err_class = pbm_err_p->pbm_pri ? 1677 PCI_PBM_RETRY : PCI_SEC_PBM_RETRY; 1678 pbm_err_p->pbm_log = FM_LOG_PBM; 1679 nerr++; 1680 } 1681 if (e & PSYCHO_PCI_AFSR_E_PERR) { 1682 *tmp_class = pbm_err_p->pbm_pri ? PCI_MDPE : PCI_SEC_MDPE; 1683 nerr++; 1684 } 1685 return (nerr); 1686 } 1687 1688 /* 1689 * Function used to clear PBM/PCI/IOMMU error state after error handling 1690 * is complete. Only clearing error bits which have been logged. Called by 1691 * pci_pbm_err_handler and pci_bus_exit. 1692 */ 1693 static void 1694 pci_clear_error(pci_t *pci_p, pbm_errstate_t *pbm_err_p) 1695 { 1696 pbm_t *pbm_p = pci_p->pci_pbm_p; 1697 1698 ASSERT(MUTEX_HELD(&pbm_p->pbm_pci_p->pci_common_p->pci_fm_mutex)); 1699 1700 *pbm_p->pbm_ctrl_reg = pbm_err_p->pbm_ctl_stat; 1701 *pbm_p->pbm_async_flt_status_reg = pbm_err_p->pbm_afsr; 1702 pbm_p->pbm_config_header->ch_status_reg = 1703 pbm_err_p->pbm_pci.pci_cfg_stat; 1704 } 1705 1706 /*ARGSUSED*/ 1707 int 1708 pci_pbm_err_handler(dev_info_t *dip, ddi_fm_error_t *derr, 1709 const void *impl_data, int caller) 1710 { 1711 int fatal = 0; 1712 int nonfatal = 0; 1713 int unknown = 0; 1714 int rserr = 0; 1715 uint32_t prierr, secerr; 1716 pbm_errstate_t pbm_err; 1717 char buf[FM_MAX_CLASS]; 1718 pci_t *pci_p = (pci_t *)impl_data; 1719 pbm_t *pbm_p = pci_p->pci_pbm_p; 1720 int ret = 0; 1721 uint64_t pbm_ctl_stat; 1722 uint16_t pci_cfg_stat; 1723 1724 ASSERT(MUTEX_HELD(&pci_p->pci_common_p->pci_fm_mutex)); 1725 pci_pbm_errstate_get(pci_p, &pbm_err); 1726 1727 derr->fme_ena = derr->fme_ena ? derr->fme_ena : 1728 fm_ena_generate(0, FM_ENA_FMT1); 1729 1730 prierr = PBM_AFSR_TO_PRIERR(pbm_err.pbm_afsr); 1731 secerr = PBM_AFSR_TO_SECERR(pbm_err.pbm_afsr); 1732 1733 if (derr->fme_flag == DDI_FM_ERR_EXPECTED) { 1734 if (caller == PCI_TRAP_CALL) { 1735 /* 1736 * For ddi_caut_get treat all events as 1737 * nonfatal. The trampoline will set 1738 * err_ena = 0, err_status = NONFATAL. We only 1739 * really call this function so that pci_clear_error() 1740 * and ndi_fm_handler_dispatch() will get called. 1741 */ 1742 derr->fme_status = DDI_FM_NONFATAL; 1743 nonfatal++; 1744 goto done; 1745 } else { 1746 /* 1747 * For ddi_caut_put treat all events as nonfatal. Here 1748 * we have the handle and can call ndi_fm_acc_err_set(). 1749 */ 1750 derr->fme_status = DDI_FM_NONFATAL; 1751 ndi_fm_acc_err_set(pbm_p->pbm_excl_handle, derr); 1752 nonfatal++; 1753 goto done; 1754 } 1755 } else if (derr->fme_flag == DDI_FM_ERR_PEEK) { 1756 /* 1757 * For ddi_peek treat all events as nonfatal. We only 1758 * really call this function so that pci_clear_error() 1759 * and ndi_fm_handler_dispatch() will get called. 1760 */ 1761 nonfatal++; 1762 goto done; 1763 } else if (derr->fme_flag == DDI_FM_ERR_POKE) { 1764 /* 1765 * For ddi_poke we can treat as nonfatal if the 1766 * following conditions are met : 1767 * 1. Make sure only primary error is MA/TA 1768 * 2. Make sure no secondary error 1769 * 3. check pci config header stat reg to see MA/TA is 1770 * logged. We cannot verify only MA/TA is recorded 1771 * since it gets much more complicated when a 1772 * PCI-to-PCI bridge is present. 1773 */ 1774 if ((prierr == PSYCHO_PCI_AFSR_E_MA) && !secerr && 1775 (pbm_err.pbm_pci.pci_cfg_stat & PCI_STAT_R_MAST_AB)) { 1776 nonfatal++; 1777 goto done; 1778 } 1779 if ((prierr == PSYCHO_PCI_AFSR_E_TA) && !secerr && 1780 (pbm_err.pbm_pci.pci_cfg_stat & PCI_STAT_R_TARG_AB)) { 1781 nonfatal++; 1782 goto done; 1783 } 1784 } 1785 1786 if (prierr || secerr) { 1787 ret = pbm_afsr_report(dip, derr->fme_ena, &pbm_err); 1788 if (ret == DDI_FM_FATAL) 1789 fatal++; 1790 else 1791 nonfatal++; 1792 } 1793 1794 ret = pci_cfg_report(dip, derr, &pbm_err.pbm_pci, caller, prierr); 1795 if (ret == DDI_FM_FATAL) 1796 fatal++; 1797 else if (ret == DDI_FM_NONFATAL) 1798 nonfatal++; 1799 1800 pbm_ctl_stat = pbm_err.pbm_ctl_stat; 1801 pci_cfg_stat = pbm_err.pbm_pci.pci_cfg_stat; 1802 1803 /* 1804 * PBM Received System Error - During any transaction, or 1805 * at any point on the bus, some device may detect a critical 1806 * error and signal a system error to the system. 1807 */ 1808 if (pbm_ctl_stat & COMMON_PCI_CTRL_SERR) { 1809 /* 1810 * may be expected (master abort from pci-pci bridge during 1811 * poke will generate SERR) 1812 */ 1813 if (derr->fme_flag != DDI_FM_ERR_POKE) { 1814 pbm_err.pbm_pci.pci_err_class = PCI_REC_SERR; 1815 (void) snprintf(buf, FM_MAX_CLASS, "%s.%s", 1816 PCI_ERROR_SUBCLASS, pbm_err.pbm_pci.pci_err_class); 1817 ddi_fm_ereport_post(dip, buf, derr->fme_ena, 1818 DDI_NOSLEEP, FM_VERSION, DATA_TYPE_UINT8, 0, 1819 PCI_CONFIG_STATUS, DATA_TYPE_UINT16, pci_cfg_stat, 1820 PCI_CONFIG_COMMAND, DATA_TYPE_UINT16, 1821 pbm_err.pbm_pci.pci_cfg_comm, PCI_PA, 1822 DATA_TYPE_UINT64, (uint64_t)0, NULL); 1823 } 1824 rserr++; 1825 } 1826 1827 /* Streaming Byte Hole Error */ 1828 if (pbm_ctl_stat & COMMON_PCI_CTRL_SBH_ERR) { 1829 if (pci_panic_on_sbh_errors) 1830 fatal++; 1831 else 1832 nonfatal++; 1833 pbm_err.pbm_err_class = PCI_PSY_SBH; 1834 pbm_ereport_post(dip, derr->fme_ena, &pbm_err); 1835 } 1836 done: 1837 ret = ndi_fm_handler_dispatch(dip, NULL, derr); 1838 if (ret == DDI_FM_FATAL) { 1839 fatal++; 1840 } else if (ret == DDI_FM_NONFATAL) { 1841 nonfatal++; 1842 } else if (ret == DDI_FM_UNKNOWN) { 1843 unknown++; 1844 } 1845 1846 /* 1847 * rserr not claimed as nonfatal by a child is treated as fatal 1848 */ 1849 if (rserr && ret != DDI_FM_NONFATAL) 1850 fatal++; 1851 1852 /* Cleanup and reset error bits */ 1853 pci_clear_error(pci_p, &pbm_err); 1854 1855 return (fatal ? DDI_FM_FATAL : (nonfatal ? DDI_FM_NONFATAL : 1856 (unknown ? DDI_FM_UNKNOWN : DDI_FM_OK))); 1857 } 1858 1859 int 1860 pci_check_error(pci_t *pci_p) 1861 { 1862 pbm_t *pbm_p = pci_p->pci_pbm_p; 1863 uint16_t pci_cfg_stat; 1864 uint64_t pbm_ctl_stat, pbm_afsr; 1865 1866 ASSERT(MUTEX_HELD(&pci_p->pci_common_p->pci_fm_mutex)); 1867 1868 pci_cfg_stat = pbm_p->pbm_config_header->ch_status_reg; 1869 pbm_ctl_stat = *pbm_p->pbm_ctrl_reg; 1870 pbm_afsr = *pbm_p->pbm_async_flt_status_reg; 1871 1872 if ((pci_cfg_stat & (PCI_STAT_S_PERROR | PCI_STAT_S_TARG_AB | 1873 PCI_STAT_R_TARG_AB | PCI_STAT_R_MAST_AB | 1874 PCI_STAT_S_SYSERR | PCI_STAT_PERROR)) || 1875 (pbm_ctl_stat & (COMMON_PCI_CTRL_SBH_ERR | 1876 COMMON_PCI_CTRL_SERR)) || 1877 (PBM_AFSR_TO_PRIERR(pbm_afsr))) 1878 return (1); 1879 1880 return (0); 1881 1882 } 1883 1884 /* 1885 * Function used to gather PBM/PCI error state for the 1886 * pci_pbm_err_handler. This function must be called while pci_fm_mutex 1887 * is held. 1888 */ 1889 static void 1890 pci_pbm_errstate_get(pci_t *pci_p, pbm_errstate_t *pbm_err_p) 1891 { 1892 pbm_t *pbm_p = pci_p->pci_pbm_p; 1893 1894 ASSERT(MUTEX_HELD(&pci_p->pci_common_p->pci_fm_mutex)); 1895 bzero(pbm_err_p, sizeof (pbm_errstate_t)); 1896 1897 /* 1898 * Capture all pbm error state for later logging 1899 */ 1900 pbm_err_p->pbm_bridge_type = PCI_BRIDGE_TYPE(pci_p->pci_common_p); 1901 pbm_err_p->pbm_pci.pci_cfg_stat = 1902 pbm_p->pbm_config_header->ch_status_reg; 1903 pbm_err_p->pbm_ctl_stat = *pbm_p->pbm_ctrl_reg; 1904 pbm_err_p->pbm_pci.pci_cfg_comm = 1905 pbm_p->pbm_config_header->ch_command_reg; 1906 pbm_err_p->pbm_afsr = *pbm_p->pbm_async_flt_status_reg; 1907 pbm_err_p->pbm_afar = *pbm_p->pbm_async_flt_addr_reg; 1908 pbm_err_p->pbm_pci.pci_pa = *pbm_p->pbm_async_flt_addr_reg; 1909 } 1910 1911 void 1912 pbm_clear_error(pbm_t *pbm_p) 1913 { 1914 uint64_t pbm_afsr, pbm_ctl_stat; 1915 1916 /* 1917 * for poke() support - called from POKE_FLUSH. Spin waiting 1918 * for MA, TA or SERR to be cleared by a pbm_error_intr(). 1919 * We have to wait for SERR too in case the device is beyond 1920 * a pci-pci bridge. 1921 */ 1922 pbm_ctl_stat = *pbm_p->pbm_ctrl_reg; 1923 pbm_afsr = *pbm_p->pbm_async_flt_status_reg; 1924 while (((pbm_afsr >> PSYCHO_PCI_AFSR_PE_SHIFT) & 1925 (PSYCHO_PCI_AFSR_E_MA | PSYCHO_PCI_AFSR_E_TA)) || 1926 (pbm_ctl_stat & COMMON_PCI_CTRL_SERR)) { 1927 pbm_ctl_stat = *pbm_p->pbm_ctrl_reg; 1928 pbm_afsr = *pbm_p->pbm_async_flt_status_reg; 1929 } 1930 } 1931 1932 /*ARGSUSED*/ 1933 void 1934 pci_format_addr(dev_info_t *dip, uint64_t *afar, uint64_t afsr) 1935 { 1936 /* 1937 * For Psycho the full address is stored in hardware. So 1938 * there is no need to format it. 1939 */ 1940 } 1941 1942 /*ARGSUSED*/ 1943 int 1944 pci_bus_quiesce(pci_t *pci_p, dev_info_t *dip, void *result) 1945 { 1946 return (DDI_FAILURE); 1947 } 1948 1949 /*ARGSUSED*/ 1950 int 1951 pci_bus_unquiesce(pci_t *pci_p, dev_info_t *dip, void *result) 1952 { 1953 return (DDI_FAILURE); 1954 } 1955 1956 void 1957 pci_vmem_free(iommu_t *iommu_p, ddi_dma_impl_t *mp, void *dvma_addr, 1958 size_t npages) 1959 { 1960 pci_vmem_do_free(iommu_p, dvma_addr, npages, 1961 (mp->dmai_flags & DMAI_FLAGS_VMEMCACHE)); 1962 } 1963 1964 1965 /* 1966 * NOTE: This call is only used by legacy systems (eg. E250 and E450) that 1967 * require unregistering the pci driver's thermal intrerrupt handler before 1968 * they can register their own. 1969 */ 1970 void 1971 pci_thermal_rem_intr(dev_info_t *rdip, uint_t inum) 1972 { 1973 pci_t *pci_p; 1974 dev_info_t *pdip; 1975 uint32_t dev_mondo, pci_mondo; 1976 int instance; 1977 1978 for (pdip = ddi_get_parent(rdip); pdip; pdip = ddi_get_parent(pdip)) { 1979 if (strcmp(ddi_driver_name(pdip), "pcipsy") == 0) 1980 break; 1981 } 1982 1983 if (!pdip) { 1984 cmn_err(CE_WARN, "pci_thermal_rem_intr() no pcipsy parent\n"); 1985 return; 1986 } 1987 1988 instance = ddi_get_instance(pdip); 1989 pci_p = get_pci_soft_state(instance); 1990 1991 /* Calculate the requesting device's mondo */ 1992 dev_mondo = pci_xlate_intr(pci_p->pci_dip, rdip, pci_p->pci_ib_p, 1993 IB_MONDO_TO_INO(i_ddi_get_inum(rdip, inum))); 1994 1995 /* get pci's thermal mondo */ 1996 pci_mondo = ((pci_p->pci_cb_p->cb_ign << PCI_INO_BITS) | 1997 pci_p->pci_inos[CBNINTR_THERMAL]); 1998 pci_mondo = CB_MONDO_TO_XMONDO(pci_p->pci_cb_p, pci_mondo); 1999 2000 if (pci_mondo == dev_mondo) { 2001 DEBUG2(DBG_ATTACH, rdip, "pci_thermal_rem_intr unregistered " 2002 "for dip=%s%d:", ddi_driver_name(rdip), 2003 ddi_get_instance(rdip)); 2004 rem_ivintr(pci_mondo, NULL); 2005 } 2006 } 2007