1 // SPDX-License-Identifier: GPL-2.0-or-later 2 /* 3 * Procedures for interfacing to Open Firmware. 4 * 5 * Paul Mackerras August 1996. 6 * Copyright (C) 1996-2005 Paul Mackerras. 7 * 8 * Adapted for 64bit PowerPC by Dave Engebretsen and Peter Bergner. 9 * {engebret|bergner}@us.ibm.com 10 */ 11 12 #undef DEBUG_PROM 13 14 /* we cannot use FORTIFY as it brings in new symbols */ 15 #define __NO_FORTIFY 16 17 #include <linux/stdarg.h> 18 #include <linux/kernel.h> 19 #include <linux/string.h> 20 #include <linux/init.h> 21 #include <linux/threads.h> 22 #include <linux/spinlock.h> 23 #include <linux/types.h> 24 #include <linux/pci.h> 25 #include <linux/proc_fs.h> 26 #include <linux/delay.h> 27 #include <linux/initrd.h> 28 #include <linux/bitops.h> 29 #include <linux/pgtable.h> 30 #include <linux/printk.h> 31 #include <asm/prom.h> 32 #include <asm/rtas.h> 33 #include <asm/page.h> 34 #include <asm/processor.h> 35 #include <asm/interrupt.h> 36 #include <asm/irq.h> 37 #include <asm/io.h> 38 #include <asm/smp.h> 39 #include <asm/mmu.h> 40 #include <asm/iommu.h> 41 #include <asm/btext.h> 42 #include <asm/sections.h> 43 #include <asm/machdep.h> 44 #include <asm/asm-prototypes.h> 45 #include <asm/ultravisor-api.h> 46 47 #include <linux/linux_logo.h> 48 49 /* All of prom_init bss lives here */ 50 #define __prombss __section(".bss.prominit") 51 52 /* 53 * Eventually bump that one up 54 */ 55 #define DEVTREE_CHUNK_SIZE 0x100000 56 57 /* 58 * This is the size of the local memory reserve map that gets copied 59 * into the boot params passed to the kernel. That size is totally 60 * flexible as the kernel just reads the list until it encounters an 61 * entry with size 0, so it can be changed without breaking binary 62 * compatibility 63 */ 64 #define MEM_RESERVE_MAP_SIZE 8 65 66 /* 67 * prom_init() is called very early on, before the kernel text 68 * and data have been mapped to KERNELBASE. At this point the code 69 * is running at whatever address it has been loaded at. 70 * On ppc32 we compile with -mrelocatable, which means that references 71 * to extern and static variables get relocated automatically. 72 * ppc64 objects are always relocatable, we just need to relocate the 73 * TOC. 74 * 75 * Because OF may have mapped I/O devices into the area starting at 76 * KERNELBASE, particularly on CHRP machines, we can't safely call 77 * OF once the kernel has been mapped to KERNELBASE. Therefore all 78 * OF calls must be done within prom_init(). 79 * 80 * ADDR is used in calls to call_prom. The 4th and following 81 * arguments to call_prom should be 32-bit values. 82 * On ppc64, 64 bit values are truncated to 32 bits (and 83 * fortunately don't get interpreted as two arguments). 84 */ 85 #define ADDR(x) (u32)(unsigned long)(x) 86 87 #ifdef CONFIG_PPC64 88 #define OF_WORKAROUNDS 0 89 #else 90 #define OF_WORKAROUNDS of_workarounds 91 static int of_workarounds __prombss; 92 #endif 93 94 #define OF_WA_CLAIM 1 /* do phys/virt claim separately, then map */ 95 #define OF_WA_LONGTRAIL 2 /* work around longtrail bugs */ 96 97 #define PROM_BUG() do { \ 98 prom_printf("kernel BUG at %s line 0x%x!\n", \ 99 __FILE__, __LINE__); \ 100 __builtin_trap(); \ 101 } while (0) 102 103 #ifdef DEBUG_PROM 104 #define prom_debug(x...) prom_printf(x) 105 #else 106 #define prom_debug(x...) do { } while (0) 107 #endif 108 109 110 typedef u32 prom_arg_t; 111 112 struct prom_args { 113 __be32 service; 114 __be32 nargs; 115 __be32 nret; 116 __be32 args[10]; 117 }; 118 119 struct prom_t { 120 ihandle root; 121 phandle chosen; 122 int cpu; 123 ihandle stdout; 124 ihandle mmumap; 125 ihandle memory; 126 }; 127 128 struct mem_map_entry { 129 __be64 base; 130 __be64 size; 131 }; 132 133 typedef __be32 cell_t; 134 135 extern void __start(unsigned long r3, unsigned long r4, unsigned long r5, 136 unsigned long r6, unsigned long r7, unsigned long r8, 137 unsigned long r9); 138 139 #ifdef CONFIG_PPC64 140 extern int enter_prom(struct prom_args *args, unsigned long entry); 141 #else 142 static inline int enter_prom(struct prom_args *args, unsigned long entry) 143 { 144 return ((int (*)(struct prom_args *))entry)(args); 145 } 146 #endif 147 148 extern void copy_and_flush(unsigned long dest, unsigned long src, 149 unsigned long size, unsigned long offset); 150 151 /* prom structure */ 152 static struct prom_t __prombss prom; 153 154 static unsigned long __prombss prom_entry; 155 156 static char __prombss of_stdout_device[256]; 157 static char __prombss prom_scratch[256]; 158 159 static unsigned long __prombss dt_header_start; 160 static unsigned long __prombss dt_struct_start, dt_struct_end; 161 static unsigned long __prombss dt_string_start, dt_string_end; 162 163 static unsigned long __prombss prom_initrd_start, prom_initrd_end; 164 165 #ifdef CONFIG_PPC64 166 static int __prombss prom_iommu_force_on; 167 static int __prombss prom_iommu_off; 168 static unsigned long __prombss prom_tce_alloc_start; 169 static unsigned long __prombss prom_tce_alloc_end; 170 #endif 171 172 #ifdef CONFIG_PPC_PSERIES 173 static bool __prombss prom_radix_disable; 174 static bool __prombss prom_radix_gtse_disable; 175 static bool __prombss prom_xive_disable; 176 #endif 177 178 #ifdef CONFIG_PPC_SVM 179 static bool __prombss prom_svm_enable; 180 #endif 181 182 struct platform_support { 183 bool hash_mmu; 184 bool radix_mmu; 185 bool radix_gtse; 186 bool xive; 187 }; 188 189 /* Platforms codes are now obsolete in the kernel. Now only used within this 190 * file and ultimately gone too. Feel free to change them if you need, they 191 * are not shared with anything outside of this file anymore 192 */ 193 #define PLATFORM_PSERIES 0x0100 194 #define PLATFORM_PSERIES_LPAR 0x0101 195 #define PLATFORM_LPAR 0x0001 196 #define PLATFORM_POWERMAC 0x0400 197 #define PLATFORM_GENERIC 0x0500 198 199 static int __prombss of_platform; 200 201 static char __prombss prom_cmd_line[COMMAND_LINE_SIZE]; 202 203 static unsigned long __prombss prom_memory_limit; 204 205 static unsigned long __prombss alloc_top; 206 static unsigned long __prombss alloc_top_high; 207 static unsigned long __prombss alloc_bottom; 208 static unsigned long __prombss rmo_top; 209 static unsigned long __prombss ram_top; 210 211 static struct mem_map_entry __prombss mem_reserve_map[MEM_RESERVE_MAP_SIZE]; 212 static int __prombss mem_reserve_cnt; 213 214 static cell_t __prombss regbuf[1024]; 215 216 static bool __prombss rtas_has_query_cpu_stopped; 217 218 219 /* 220 * Error results ... some OF calls will return "-1" on error, some 221 * will return 0, some will return either. To simplify, here are 222 * macros to use with any ihandle or phandle return value to check if 223 * it is valid 224 */ 225 226 #define PROM_ERROR (-1u) 227 #define PHANDLE_VALID(p) ((p) != 0 && (p) != PROM_ERROR) 228 #define IHANDLE_VALID(i) ((i) != 0 && (i) != PROM_ERROR) 229 230 /* Copied from lib/string.c and lib/kstrtox.c */ 231 232 static int __init prom_strcmp(const char *cs, const char *ct) 233 { 234 unsigned char c1, c2; 235 236 while (1) { 237 c1 = *cs++; 238 c2 = *ct++; 239 if (c1 != c2) 240 return c1 < c2 ? -1 : 1; 241 if (!c1) 242 break; 243 } 244 return 0; 245 } 246 247 static ssize_t __init prom_strscpy_pad(char *dest, const char *src, size_t n) 248 { 249 ssize_t rc; 250 size_t i; 251 252 if (n == 0 || n > INT_MAX) 253 return -E2BIG; 254 255 // Copy up to n bytes 256 for (i = 0; i < n && src[i] != '\0'; i++) 257 dest[i] = src[i]; 258 259 rc = i; 260 261 // If we copied all n then we have run out of space for the nul 262 if (rc == n) { 263 // Rewind by one character to ensure nul termination 264 i--; 265 rc = -E2BIG; 266 } 267 268 for (; i < n; i++) 269 dest[i] = '\0'; 270 271 return rc; 272 } 273 274 static int __init prom_strncmp(const char *cs, const char *ct, size_t count) 275 { 276 unsigned char c1, c2; 277 278 while (count) { 279 c1 = *cs++; 280 c2 = *ct++; 281 if (c1 != c2) 282 return c1 < c2 ? -1 : 1; 283 if (!c1) 284 break; 285 count--; 286 } 287 return 0; 288 } 289 290 static size_t __init prom_strlen(const char *s) 291 { 292 const char *sc; 293 294 for (sc = s; *sc != '\0'; ++sc) 295 /* nothing */; 296 return sc - s; 297 } 298 299 static int __init prom_memcmp(const void *cs, const void *ct, size_t count) 300 { 301 const unsigned char *su1, *su2; 302 int res = 0; 303 304 for (su1 = cs, su2 = ct; 0 < count; ++su1, ++su2, count--) 305 if ((res = *su1 - *su2) != 0) 306 break; 307 return res; 308 } 309 310 static char __init *prom_strstr(const char *s1, const char *s2) 311 { 312 size_t l1, l2; 313 314 l2 = prom_strlen(s2); 315 if (!l2) 316 return (char *)s1; 317 l1 = prom_strlen(s1); 318 while (l1 >= l2) { 319 l1--; 320 if (!prom_memcmp(s1, s2, l2)) 321 return (char *)s1; 322 s1++; 323 } 324 return NULL; 325 } 326 327 static size_t __init prom_strlcat(char *dest, const char *src, size_t count) 328 { 329 size_t dsize = prom_strlen(dest); 330 size_t len = prom_strlen(src); 331 size_t res = dsize + len; 332 333 /* This would be a bug */ 334 if (dsize >= count) 335 return count; 336 337 dest += dsize; 338 count -= dsize; 339 if (len >= count) 340 len = count-1; 341 memcpy(dest, src, len); 342 dest[len] = 0; 343 return res; 344 345 } 346 347 #ifdef CONFIG_PPC_PSERIES 348 static int __init prom_strtobool(const char *s, bool *res) 349 { 350 if (!s) 351 return -EINVAL; 352 353 switch (s[0]) { 354 case 'y': 355 case 'Y': 356 case '1': 357 *res = true; 358 return 0; 359 case 'n': 360 case 'N': 361 case '0': 362 *res = false; 363 return 0; 364 case 'o': 365 case 'O': 366 switch (s[1]) { 367 case 'n': 368 case 'N': 369 *res = true; 370 return 0; 371 case 'f': 372 case 'F': 373 *res = false; 374 return 0; 375 default: 376 break; 377 } 378 break; 379 default: 380 break; 381 } 382 383 return -EINVAL; 384 } 385 #endif 386 387 /* This is the one and *ONLY* place where we actually call open 388 * firmware. 389 */ 390 391 static int __init call_prom(const char *service, int nargs, int nret, ...) 392 { 393 int i; 394 struct prom_args args; 395 va_list list; 396 397 args.service = cpu_to_be32(ADDR(service)); 398 args.nargs = cpu_to_be32(nargs); 399 args.nret = cpu_to_be32(nret); 400 401 va_start(list, nret); 402 for (i = 0; i < nargs; i++) 403 args.args[i] = cpu_to_be32(va_arg(list, prom_arg_t)); 404 va_end(list); 405 406 for (i = 0; i < nret; i++) 407 args.args[nargs+i] = 0; 408 409 if (enter_prom(&args, prom_entry) < 0) 410 return PROM_ERROR; 411 412 return (nret > 0) ? be32_to_cpu(args.args[nargs]) : 0; 413 } 414 415 static int __init call_prom_ret(const char *service, int nargs, int nret, 416 prom_arg_t *rets, ...) 417 { 418 int i; 419 struct prom_args args; 420 va_list list; 421 422 args.service = cpu_to_be32(ADDR(service)); 423 args.nargs = cpu_to_be32(nargs); 424 args.nret = cpu_to_be32(nret); 425 426 va_start(list, rets); 427 for (i = 0; i < nargs; i++) 428 args.args[i] = cpu_to_be32(va_arg(list, prom_arg_t)); 429 va_end(list); 430 431 for (i = 0; i < nret; i++) 432 args.args[nargs+i] = 0; 433 434 if (enter_prom(&args, prom_entry) < 0) 435 return PROM_ERROR; 436 437 if (rets != NULL) 438 for (i = 1; i < nret; ++i) 439 rets[i-1] = be32_to_cpu(args.args[nargs+i]); 440 441 return (nret > 0) ? be32_to_cpu(args.args[nargs]) : 0; 442 } 443 444 445 static void __init prom_print(const char *msg) 446 { 447 const char *p, *q; 448 449 if (prom.stdout == 0) 450 return; 451 452 for (p = msg; *p != 0; p = q) { 453 for (q = p; *q != 0 && *q != '\n'; ++q) 454 ; 455 if (q > p) 456 call_prom("write", 3, 1, prom.stdout, p, q - p); 457 if (*q == 0) 458 break; 459 ++q; 460 call_prom("write", 3, 1, prom.stdout, ADDR("\r\n"), 2); 461 } 462 } 463 464 465 /* 466 * Both prom_print_hex & prom_print_dec takes an unsigned long as input so that 467 * we do not need __udivdi3 or __umoddi3 on 32bits. 468 */ 469 static void __init prom_print_hex(unsigned long val) 470 { 471 int i, nibbles = sizeof(val)*2; 472 char buf[sizeof(val)*2+1]; 473 474 for (i = nibbles-1; i >= 0; i--) { 475 buf[i] = (val & 0xf) + '0'; 476 if (buf[i] > '9') 477 buf[i] += ('a'-'0'-10); 478 val >>= 4; 479 } 480 buf[nibbles] = '\0'; 481 call_prom("write", 3, 1, prom.stdout, buf, nibbles); 482 } 483 484 /* max number of decimal digits in an unsigned long */ 485 #define UL_DIGITS 21 486 static void __init prom_print_dec(unsigned long val) 487 { 488 int i, size; 489 char buf[UL_DIGITS+1]; 490 491 for (i = UL_DIGITS-1; i >= 0; i--) { 492 buf[i] = (val % 10) + '0'; 493 val = val/10; 494 if (val == 0) 495 break; 496 } 497 /* shift stuff down */ 498 size = UL_DIGITS - i; 499 call_prom("write", 3, 1, prom.stdout, buf+i, size); 500 } 501 502 __printf(1, 2) 503 static void __init prom_printf(const char *format, ...) 504 { 505 const char *p, *q, *s; 506 va_list args; 507 unsigned long v; 508 long vs; 509 int n = 0; 510 511 va_start(args, format); 512 for (p = format; *p != 0; p = q) { 513 for (q = p; *q != 0 && *q != '\n' && *q != '%'; ++q) 514 ; 515 if (q > p) 516 call_prom("write", 3, 1, prom.stdout, p, q - p); 517 if (*q == 0) 518 break; 519 if (*q == '\n') { 520 ++q; 521 call_prom("write", 3, 1, prom.stdout, 522 ADDR("\r\n"), 2); 523 continue; 524 } 525 ++q; 526 if (*q == 0) 527 break; 528 while (*q == 'l') { 529 ++q; 530 ++n; 531 } 532 switch (*q) { 533 case 's': 534 ++q; 535 s = va_arg(args, const char *); 536 prom_print(s); 537 break; 538 case 'x': 539 ++q; 540 switch (n) { 541 case 0: 542 v = va_arg(args, unsigned int); 543 break; 544 case 1: 545 v = va_arg(args, unsigned long); 546 break; 547 case 2: 548 default: 549 v = va_arg(args, unsigned long long); 550 break; 551 } 552 prom_print_hex(v); 553 break; 554 case 'u': 555 ++q; 556 switch (n) { 557 case 0: 558 v = va_arg(args, unsigned int); 559 break; 560 case 1: 561 v = va_arg(args, unsigned long); 562 break; 563 case 2: 564 default: 565 v = va_arg(args, unsigned long long); 566 break; 567 } 568 prom_print_dec(v); 569 break; 570 case 'd': 571 ++q; 572 switch (n) { 573 case 0: 574 vs = va_arg(args, int); 575 break; 576 case 1: 577 vs = va_arg(args, long); 578 break; 579 case 2: 580 default: 581 vs = va_arg(args, long long); 582 break; 583 } 584 if (vs < 0) { 585 prom_print("-"); 586 vs = -vs; 587 } 588 prom_print_dec(vs); 589 break; 590 } 591 } 592 va_end(args); 593 } 594 595 596 static unsigned int __init prom_claim(unsigned long virt, unsigned long size, 597 unsigned long align) 598 { 599 600 if (align == 0 && (OF_WORKAROUNDS & OF_WA_CLAIM)) { 601 /* 602 * Old OF requires we claim physical and virtual separately 603 * and then map explicitly (assuming virtual mode) 604 */ 605 int ret; 606 prom_arg_t result; 607 608 ret = call_prom_ret("call-method", 5, 2, &result, 609 ADDR("claim"), prom.memory, 610 align, size, virt); 611 if (ret != 0 || result == -1) 612 return -1; 613 ret = call_prom_ret("call-method", 5, 2, &result, 614 ADDR("claim"), prom.mmumap, 615 align, size, virt); 616 if (ret != 0) { 617 call_prom("call-method", 4, 1, ADDR("release"), 618 prom.memory, size, virt); 619 return -1; 620 } 621 /* the 0x12 is M (coherence) + PP == read/write */ 622 call_prom("call-method", 6, 1, 623 ADDR("map"), prom.mmumap, 0x12, size, virt, virt); 624 return virt; 625 } 626 return call_prom("claim", 3, 1, (prom_arg_t)virt, (prom_arg_t)size, 627 (prom_arg_t)align); 628 } 629 630 static void __init __attribute__((noreturn)) prom_panic(const char *reason) 631 { 632 prom_print(reason); 633 /* Do not call exit because it clears the screen on pmac 634 * it also causes some sort of double-fault on early pmacs */ 635 if (of_platform == PLATFORM_POWERMAC) 636 asm("trap\n"); 637 638 /* ToDo: should put up an SRC here on pSeries */ 639 call_prom("exit", 0, 0); 640 641 for (;;) /* should never get here */ 642 ; 643 } 644 645 646 static int __init prom_next_node(phandle *nodep) 647 { 648 phandle node; 649 650 if ((node = *nodep) != 0 651 && (*nodep = call_prom("child", 1, 1, node)) != 0) 652 return 1; 653 if ((*nodep = call_prom("peer", 1, 1, node)) != 0) 654 return 1; 655 for (;;) { 656 if ((node = call_prom("parent", 1, 1, node)) == 0) 657 return 0; 658 if ((*nodep = call_prom("peer", 1, 1, node)) != 0) 659 return 1; 660 } 661 } 662 663 static inline int __init prom_getprop(phandle node, const char *pname, 664 void *value, size_t valuelen) 665 { 666 return call_prom("getprop", 4, 1, node, ADDR(pname), 667 (u32)(unsigned long) value, (u32) valuelen); 668 } 669 670 static inline int __init prom_getproplen(phandle node, const char *pname) 671 { 672 return call_prom("getproplen", 2, 1, node, ADDR(pname)); 673 } 674 675 static void __init add_string(char **str, const char *q) 676 { 677 char *p = *str; 678 679 while (*q) 680 *p++ = *q++; 681 *p++ = ' '; 682 *str = p; 683 } 684 685 static char *__init tohex(unsigned int x) 686 { 687 static const char digits[] __initconst = "0123456789abcdef"; 688 static char result[9] __prombss; 689 int i; 690 691 result[8] = 0; 692 i = 8; 693 do { 694 --i; 695 result[i] = digits[x & 0xf]; 696 x >>= 4; 697 } while (x != 0 && i > 0); 698 return &result[i]; 699 } 700 701 static int __init prom_setprop(phandle node, const char *nodename, 702 const char *pname, void *value, size_t valuelen) 703 { 704 char cmd[256], *p; 705 706 if (!(OF_WORKAROUNDS & OF_WA_LONGTRAIL)) 707 return call_prom("setprop", 4, 1, node, ADDR(pname), 708 (u32)(unsigned long) value, (u32) valuelen); 709 710 /* gah... setprop doesn't work on longtrail, have to use interpret */ 711 p = cmd; 712 add_string(&p, "dev"); 713 add_string(&p, nodename); 714 add_string(&p, tohex((u32)(unsigned long) value)); 715 add_string(&p, tohex(valuelen)); 716 add_string(&p, tohex(ADDR(pname))); 717 add_string(&p, tohex(prom_strlen(pname))); 718 add_string(&p, "property"); 719 *p = 0; 720 return call_prom("interpret", 1, 1, (u32)(unsigned long) cmd); 721 } 722 723 /* We can't use the standard versions because of relocation headaches. */ 724 #define prom_isxdigit(c) \ 725 (('0' <= (c) && (c) <= '9') || ('a' <= (c) && (c) <= 'f') || ('A' <= (c) && (c) <= 'F')) 726 727 #define prom_isdigit(c) ('0' <= (c) && (c) <= '9') 728 #define prom_islower(c) ('a' <= (c) && (c) <= 'z') 729 #define prom_toupper(c) (prom_islower(c) ? ((c) - 'a' + 'A') : (c)) 730 731 static unsigned long __init prom_strtoul(const char *cp, const char **endp) 732 { 733 unsigned long result = 0, base = 10, value; 734 735 if (*cp == '0') { 736 base = 8; 737 cp++; 738 if (prom_toupper(*cp) == 'X') { 739 cp++; 740 base = 16; 741 } 742 } 743 744 while (prom_isxdigit(*cp) && 745 (value = prom_isdigit(*cp) ? *cp - '0' : prom_toupper(*cp) - 'A' + 10) < base) { 746 result = result * base + value; 747 cp++; 748 } 749 750 if (endp) 751 *endp = cp; 752 753 return result; 754 } 755 756 static unsigned long __init prom_memparse(const char *ptr, const char **retptr) 757 { 758 unsigned long ret = prom_strtoul(ptr, retptr); 759 int shift = 0; 760 761 /* 762 * We can't use a switch here because GCC *may* generate a 763 * jump table which won't work, because we're not running at 764 * the address we're linked at. 765 */ 766 if ('G' == **retptr || 'g' == **retptr) 767 shift = 30; 768 769 if ('M' == **retptr || 'm' == **retptr) 770 shift = 20; 771 772 if ('K' == **retptr || 'k' == **retptr) 773 shift = 10; 774 775 if (shift) { 776 ret <<= shift; 777 (*retptr)++; 778 } 779 780 return ret; 781 } 782 783 /* 784 * Early parsing of the command line passed to the kernel, used for 785 * "mem=x" and the options that affect the iommu 786 */ 787 static void __init early_cmdline_parse(void) 788 { 789 const char *opt; 790 791 char *p; 792 int l = 0; 793 794 prom_cmd_line[0] = 0; 795 p = prom_cmd_line; 796 797 if (!IS_ENABLED(CONFIG_CMDLINE_FORCE) && (long)prom.chosen > 0) 798 l = prom_getprop(prom.chosen, "bootargs", p, COMMAND_LINE_SIZE-1); 799 800 if (IS_ENABLED(CONFIG_CMDLINE_EXTEND) || l <= 0 || p[0] == '\0') 801 prom_strlcat(prom_cmd_line, " " CONFIG_CMDLINE, 802 sizeof(prom_cmd_line)); 803 804 prom_printf("command line: %s\n", prom_cmd_line); 805 806 #ifdef CONFIG_PPC64 807 opt = prom_strstr(prom_cmd_line, "iommu="); 808 if (opt) { 809 prom_printf("iommu opt is: %s\n", opt); 810 opt += 6; 811 while (*opt && *opt == ' ') 812 opt++; 813 if (!prom_strncmp(opt, "off", 3)) 814 prom_iommu_off = 1; 815 else if (!prom_strncmp(opt, "force", 5)) 816 prom_iommu_force_on = 1; 817 } 818 #endif 819 opt = prom_strstr(prom_cmd_line, "mem="); 820 if (opt) { 821 opt += 4; 822 prom_memory_limit = prom_memparse(opt, (const char **)&opt); 823 #ifdef CONFIG_PPC64 824 /* Align to 16 MB == size of ppc64 large page */ 825 prom_memory_limit = ALIGN(prom_memory_limit, 0x1000000); 826 #endif 827 } 828 829 #ifdef CONFIG_PPC_PSERIES 830 prom_radix_disable = !IS_ENABLED(CONFIG_PPC_RADIX_MMU_DEFAULT); 831 opt = prom_strstr(prom_cmd_line, "disable_radix"); 832 if (opt) { 833 opt += 13; 834 if (*opt && *opt == '=') { 835 bool val; 836 837 if (prom_strtobool(++opt, &val)) 838 prom_radix_disable = false; 839 else 840 prom_radix_disable = val; 841 } else 842 prom_radix_disable = true; 843 } 844 if (prom_radix_disable) 845 prom_debug("Radix disabled from cmdline\n"); 846 847 opt = prom_strstr(prom_cmd_line, "radix_hcall_invalidate=on"); 848 if (opt) { 849 prom_radix_gtse_disable = true; 850 prom_debug("Radix GTSE disabled from cmdline\n"); 851 } 852 853 opt = prom_strstr(prom_cmd_line, "xive=off"); 854 if (opt) { 855 prom_xive_disable = true; 856 prom_debug("XIVE disabled from cmdline\n"); 857 } 858 #endif /* CONFIG_PPC_PSERIES */ 859 860 #ifdef CONFIG_PPC_SVM 861 opt = prom_strstr(prom_cmd_line, "svm="); 862 if (opt) { 863 bool val; 864 865 opt += sizeof("svm=") - 1; 866 if (!prom_strtobool(opt, &val)) 867 prom_svm_enable = val; 868 } 869 #endif /* CONFIG_PPC_SVM */ 870 } 871 872 #ifdef CONFIG_PPC_PSERIES 873 /* 874 * The architecture vector has an array of PVR mask/value pairs, 875 * followed by # option vectors - 1, followed by the option vectors. 876 * 877 * See prom.h for the definition of the bits specified in the 878 * architecture vector. 879 */ 880 881 /* Firmware expects the value to be n - 1, where n is the # of vectors */ 882 #define NUM_VECTORS(n) ((n) - 1) 883 884 /* 885 * Firmware expects 1 + n - 2, where n is the length of the option vector in 886 * bytes. The 1 accounts for the length byte itself, the - 2 .. ? 887 */ 888 #define VECTOR_LENGTH(n) (1 + (n) - 2) 889 890 struct option_vector1 { 891 u8 byte1; 892 u8 arch_versions; 893 u8 arch_versions3; 894 } __packed; 895 896 struct option_vector2 { 897 u8 byte1; 898 __be16 reserved; 899 __be32 real_base; 900 __be32 real_size; 901 __be32 virt_base; 902 __be32 virt_size; 903 __be32 load_base; 904 __be32 min_rma; 905 __be32 min_load; 906 u8 min_rma_percent; 907 u8 max_pft_size; 908 } __packed; 909 910 struct option_vector3 { 911 u8 byte1; 912 u8 byte2; 913 } __packed; 914 915 struct option_vector4 { 916 u8 byte1; 917 u8 min_vp_cap; 918 } __packed; 919 920 struct option_vector5 { 921 u8 byte1; 922 u8 byte2; 923 u8 byte3; 924 u8 cmo; 925 u8 associativity; 926 u8 bin_opts; 927 u8 micro_checkpoint; 928 u8 reserved0; 929 __be32 max_cpus; 930 __be16 papr_level; 931 __be16 reserved1; 932 u8 platform_facilities; 933 u8 reserved2; 934 __be16 reserved3; 935 u8 subprocessors; 936 u8 byte22; 937 u8 intarch; 938 u8 mmu; 939 u8 hash_ext; 940 u8 radix_ext; 941 } __packed; 942 943 struct option_vector6 { 944 u8 reserved; 945 u8 secondary_pteg; 946 u8 os_name; 947 } __packed; 948 949 struct option_vector7 { 950 u8 os_id[256]; 951 } __packed; 952 953 struct ibm_arch_vec { 954 struct { u32 mask, val; } pvrs[14]; 955 956 u8 num_vectors; 957 958 u8 vec1_len; 959 struct option_vector1 vec1; 960 961 u8 vec2_len; 962 struct option_vector2 vec2; 963 964 u8 vec3_len; 965 struct option_vector3 vec3; 966 967 u8 vec4_len; 968 struct option_vector4 vec4; 969 970 u8 vec5_len; 971 struct option_vector5 vec5; 972 973 u8 vec6_len; 974 struct option_vector6 vec6; 975 976 u8 vec7_len; 977 struct option_vector7 vec7; 978 } __packed; 979 980 static const struct ibm_arch_vec ibm_architecture_vec_template __initconst = { 981 .pvrs = { 982 { 983 .mask = cpu_to_be32(0xfffe0000), /* POWER5/POWER5+ */ 984 .val = cpu_to_be32(0x003a0000), 985 }, 986 { 987 .mask = cpu_to_be32(0xffff0000), /* POWER6 */ 988 .val = cpu_to_be32(0x003e0000), 989 }, 990 { 991 .mask = cpu_to_be32(0xffff0000), /* POWER7 */ 992 .val = cpu_to_be32(0x003f0000), 993 }, 994 { 995 .mask = cpu_to_be32(0xffff0000), /* POWER8E */ 996 .val = cpu_to_be32(0x004b0000), 997 }, 998 { 999 .mask = cpu_to_be32(0xffff0000), /* POWER8NVL */ 1000 .val = cpu_to_be32(0x004c0000), 1001 }, 1002 { 1003 .mask = cpu_to_be32(0xffff0000), /* POWER8 */ 1004 .val = cpu_to_be32(0x004d0000), 1005 }, 1006 { 1007 .mask = cpu_to_be32(0xffff0000), /* POWER9 */ 1008 .val = cpu_to_be32(0x004e0000), 1009 }, 1010 { 1011 .mask = cpu_to_be32(0xffff0000), /* POWER10 */ 1012 .val = cpu_to_be32(0x00800000), 1013 }, 1014 { 1015 .mask = cpu_to_be32(0xffffffff), /* all 3.1-compliant */ 1016 .val = cpu_to_be32(0x0f000006), 1017 }, 1018 { 1019 .mask = cpu_to_be32(0xffffffff), /* all 3.00-compliant */ 1020 .val = cpu_to_be32(0x0f000005), 1021 }, 1022 { 1023 .mask = cpu_to_be32(0xffffffff), /* all 2.07-compliant */ 1024 .val = cpu_to_be32(0x0f000004), 1025 }, 1026 { 1027 .mask = cpu_to_be32(0xffffffff), /* all 2.06-compliant */ 1028 .val = cpu_to_be32(0x0f000003), 1029 }, 1030 { 1031 .mask = cpu_to_be32(0xffffffff), /* all 2.05-compliant */ 1032 .val = cpu_to_be32(0x0f000002), 1033 }, 1034 { 1035 .mask = cpu_to_be32(0xfffffffe), /* all 2.04-compliant and earlier */ 1036 .val = cpu_to_be32(0x0f000001), 1037 }, 1038 }, 1039 1040 .num_vectors = NUM_VECTORS(6), 1041 1042 .vec1_len = VECTOR_LENGTH(sizeof(struct option_vector1)), 1043 .vec1 = { 1044 .byte1 = 0, 1045 .arch_versions = OV1_PPC_2_00 | OV1_PPC_2_01 | OV1_PPC_2_02 | OV1_PPC_2_03 | 1046 OV1_PPC_2_04 | OV1_PPC_2_05 | OV1_PPC_2_06 | OV1_PPC_2_07, 1047 .arch_versions3 = OV1_PPC_3_00 | OV1_PPC_3_1, 1048 }, 1049 1050 .vec2_len = VECTOR_LENGTH(sizeof(struct option_vector2)), 1051 /* option vector 2: Open Firmware options supported */ 1052 .vec2 = { 1053 .byte1 = OV2_REAL_MODE, 1054 .reserved = 0, 1055 .real_base = cpu_to_be32(0xffffffff), 1056 .real_size = cpu_to_be32(0xffffffff), 1057 .virt_base = cpu_to_be32(0xffffffff), 1058 .virt_size = cpu_to_be32(0xffffffff), 1059 .load_base = cpu_to_be32(0xffffffff), 1060 .min_rma = cpu_to_be32(512), /* 512MB min RMA */ 1061 .min_load = cpu_to_be32(0xffffffff), /* full client load */ 1062 .min_rma_percent = 0, /* min RMA percentage of total RAM */ 1063 .max_pft_size = 48, /* max log_2(hash table size) */ 1064 }, 1065 1066 .vec3_len = VECTOR_LENGTH(sizeof(struct option_vector3)), 1067 /* option vector 3: processor options supported */ 1068 .vec3 = { 1069 .byte1 = 0, /* don't ignore, don't halt */ 1070 .byte2 = OV3_FP | OV3_VMX | OV3_DFP, 1071 }, 1072 1073 .vec4_len = VECTOR_LENGTH(sizeof(struct option_vector4)), 1074 /* option vector 4: IBM PAPR implementation */ 1075 .vec4 = { 1076 .byte1 = 0, /* don't halt */ 1077 .min_vp_cap = OV4_MIN_ENT_CAP, /* minimum VP entitled capacity */ 1078 }, 1079 1080 .vec5_len = VECTOR_LENGTH(sizeof(struct option_vector5)), 1081 /* option vector 5: PAPR/OF options */ 1082 .vec5 = { 1083 .byte1 = 0, /* don't ignore, don't halt */ 1084 .byte2 = OV5_FEAT(OV5_LPAR) | OV5_FEAT(OV5_SPLPAR) | OV5_FEAT(OV5_LARGE_PAGES) | 1085 OV5_FEAT(OV5_DRCONF_MEMORY) | OV5_FEAT(OV5_DONATE_DEDICATE_CPU) | 1086 #ifdef CONFIG_PCI_MSI 1087 /* PCIe/MSI support. Without MSI full PCIe is not supported */ 1088 OV5_FEAT(OV5_MSI), 1089 #else 1090 0, 1091 #endif 1092 .byte3 = 0, 1093 .cmo = 1094 #ifdef CONFIG_PPC_SMLPAR 1095 OV5_FEAT(OV5_CMO) | OV5_FEAT(OV5_XCMO), 1096 #else 1097 0, 1098 #endif 1099 .associativity = OV5_FEAT(OV5_FORM1_AFFINITY) | OV5_FEAT(OV5_PRRN) | 1100 OV5_FEAT(OV5_FORM2_AFFINITY), 1101 .bin_opts = OV5_FEAT(OV5_RESIZE_HPT) | OV5_FEAT(OV5_HP_EVT), 1102 .micro_checkpoint = 0, 1103 .reserved0 = 0, 1104 .max_cpus = cpu_to_be32(NR_CPUS), /* number of cores supported */ 1105 .papr_level = 0, 1106 .reserved1 = 0, 1107 .platform_facilities = OV5_FEAT(OV5_PFO_HW_RNG) | OV5_FEAT(OV5_PFO_HW_ENCR) | OV5_FEAT(OV5_PFO_HW_842), 1108 .reserved2 = 0, 1109 .reserved3 = 0, 1110 .subprocessors = 1, 1111 .byte22 = OV5_FEAT(OV5_DRMEM_V2) | OV5_FEAT(OV5_DRC_INFO), 1112 .intarch = 0, 1113 .mmu = 0, 1114 .hash_ext = 0, 1115 .radix_ext = 0, 1116 }, 1117 1118 /* option vector 6: IBM PAPR hints */ 1119 .vec6_len = VECTOR_LENGTH(sizeof(struct option_vector6)), 1120 .vec6 = { 1121 .reserved = 0, 1122 .secondary_pteg = 0, 1123 .os_name = OV6_LINUX, 1124 }, 1125 1126 /* option vector 7: OS Identification */ 1127 .vec7_len = VECTOR_LENGTH(sizeof(struct option_vector7)), 1128 }; 1129 1130 static struct ibm_arch_vec __prombss ibm_architecture_vec ____cacheline_aligned; 1131 1132 /* Old method - ELF header with PT_NOTE sections only works on BE */ 1133 #ifdef __BIG_ENDIAN__ 1134 static const struct fake_elf { 1135 Elf32_Ehdr elfhdr; 1136 Elf32_Phdr phdr[2]; 1137 struct chrpnote { 1138 u32 namesz; 1139 u32 descsz; 1140 u32 type; 1141 char name[8]; /* "PowerPC" */ 1142 struct chrpdesc { 1143 u32 real_mode; 1144 u32 real_base; 1145 u32 real_size; 1146 u32 virt_base; 1147 u32 virt_size; 1148 u32 load_base; 1149 } chrpdesc; 1150 } chrpnote; 1151 struct rpanote { 1152 u32 namesz; 1153 u32 descsz; 1154 u32 type; 1155 char name[24]; /* "IBM,RPA-Client-Config" */ 1156 struct rpadesc { 1157 u32 lpar_affinity; 1158 u32 min_rmo_size; 1159 u32 min_rmo_percent; 1160 u32 max_pft_size; 1161 u32 splpar; 1162 u32 min_load; 1163 u32 new_mem_def; 1164 u32 ignore_me; 1165 } rpadesc; 1166 } rpanote; 1167 } fake_elf __initconst = { 1168 .elfhdr = { 1169 .e_ident = { 0x7f, 'E', 'L', 'F', 1170 ELFCLASS32, ELFDATA2MSB, EV_CURRENT }, 1171 .e_type = ET_EXEC, /* yeah right */ 1172 .e_machine = EM_PPC, 1173 .e_version = EV_CURRENT, 1174 .e_phoff = offsetof(struct fake_elf, phdr), 1175 .e_phentsize = sizeof(Elf32_Phdr), 1176 .e_phnum = 2 1177 }, 1178 .phdr = { 1179 [0] = { 1180 .p_type = PT_NOTE, 1181 .p_offset = offsetof(struct fake_elf, chrpnote), 1182 .p_filesz = sizeof(struct chrpnote) 1183 }, [1] = { 1184 .p_type = PT_NOTE, 1185 .p_offset = offsetof(struct fake_elf, rpanote), 1186 .p_filesz = sizeof(struct rpanote) 1187 } 1188 }, 1189 .chrpnote = { 1190 .namesz = sizeof("PowerPC"), 1191 .descsz = sizeof(struct chrpdesc), 1192 .type = 0x1275, 1193 .name = "PowerPC", 1194 .chrpdesc = { 1195 .real_mode = ~0U, /* ~0 means "don't care" */ 1196 .real_base = ~0U, 1197 .real_size = ~0U, 1198 .virt_base = ~0U, 1199 .virt_size = ~0U, 1200 .load_base = ~0U 1201 }, 1202 }, 1203 .rpanote = { 1204 .namesz = sizeof("IBM,RPA-Client-Config"), 1205 .descsz = sizeof(struct rpadesc), 1206 .type = 0x12759999, 1207 .name = "IBM,RPA-Client-Config", 1208 .rpadesc = { 1209 .lpar_affinity = 0, 1210 .min_rmo_size = 64, /* in megabytes */ 1211 .min_rmo_percent = 0, 1212 .max_pft_size = 48, /* 2^48 bytes max PFT size */ 1213 .splpar = 1, 1214 .min_load = ~0U, 1215 .new_mem_def = 0 1216 } 1217 } 1218 }; 1219 #endif /* __BIG_ENDIAN__ */ 1220 1221 static int __init prom_count_smt_threads(void) 1222 { 1223 phandle node; 1224 char type[64]; 1225 unsigned int plen; 1226 1227 /* Pick up th first CPU node we can find */ 1228 for (node = 0; prom_next_node(&node); ) { 1229 type[0] = 0; 1230 prom_getprop(node, "device_type", type, sizeof(type)); 1231 1232 if (prom_strcmp(type, "cpu")) 1233 continue; 1234 /* 1235 * There is an entry for each smt thread, each entry being 1236 * 4 bytes long. All cpus should have the same number of 1237 * smt threads, so return after finding the first. 1238 */ 1239 plen = prom_getproplen(node, "ibm,ppc-interrupt-server#s"); 1240 if (plen == PROM_ERROR) 1241 break; 1242 plen >>= 2; 1243 prom_debug("Found %lu smt threads per core\n", (unsigned long)plen); 1244 1245 /* Sanity check */ 1246 if (plen < 1 || plen > 64) { 1247 prom_printf("Threads per core %lu out of bounds, assuming 1\n", 1248 (unsigned long)plen); 1249 return 1; 1250 } 1251 return plen; 1252 } 1253 prom_debug("No threads found, assuming 1 per core\n"); 1254 1255 return 1; 1256 1257 } 1258 1259 static void __init prom_parse_mmu_model(u8 val, 1260 struct platform_support *support) 1261 { 1262 switch (val) { 1263 case OV5_FEAT(OV5_MMU_DYNAMIC): 1264 case OV5_FEAT(OV5_MMU_EITHER): /* Either Available */ 1265 prom_debug("MMU - either supported\n"); 1266 support->radix_mmu = !prom_radix_disable; 1267 support->hash_mmu = true; 1268 break; 1269 case OV5_FEAT(OV5_MMU_RADIX): /* Only Radix */ 1270 prom_debug("MMU - radix only\n"); 1271 if (prom_radix_disable) { 1272 /* 1273 * If we __have__ to do radix, we're better off ignoring 1274 * the command line rather than not booting. 1275 */ 1276 prom_printf("WARNING: Ignoring cmdline option disable_radix\n"); 1277 } 1278 support->radix_mmu = true; 1279 break; 1280 case OV5_FEAT(OV5_MMU_HASH): 1281 prom_debug("MMU - hash only\n"); 1282 support->hash_mmu = true; 1283 break; 1284 default: 1285 prom_debug("Unknown mmu support option: 0x%x\n", val); 1286 break; 1287 } 1288 } 1289 1290 static void __init prom_parse_xive_model(u8 val, 1291 struct platform_support *support) 1292 { 1293 switch (val) { 1294 case OV5_FEAT(OV5_XIVE_EITHER): /* Either Available */ 1295 prom_debug("XIVE - either mode supported\n"); 1296 support->xive = !prom_xive_disable; 1297 break; 1298 case OV5_FEAT(OV5_XIVE_EXPLOIT): /* Only Exploitation mode */ 1299 prom_debug("XIVE - exploitation mode supported\n"); 1300 if (prom_xive_disable) { 1301 /* 1302 * If we __have__ to do XIVE, we're better off ignoring 1303 * the command line rather than not booting. 1304 */ 1305 prom_printf("WARNING: Ignoring cmdline option xive=off\n"); 1306 } 1307 support->xive = true; 1308 break; 1309 case OV5_FEAT(OV5_XIVE_LEGACY): /* Only Legacy mode */ 1310 prom_debug("XIVE - legacy mode supported\n"); 1311 break; 1312 default: 1313 prom_debug("Unknown xive support option: 0x%x\n", val); 1314 break; 1315 } 1316 } 1317 1318 static void __init prom_parse_platform_support(u8 index, u8 val, 1319 struct platform_support *support) 1320 { 1321 switch (index) { 1322 case OV5_INDX(OV5_MMU_SUPPORT): /* MMU Model */ 1323 prom_parse_mmu_model(val & OV5_FEAT(OV5_MMU_SUPPORT), support); 1324 break; 1325 case OV5_INDX(OV5_RADIX_GTSE): /* Radix Extensions */ 1326 if (val & OV5_FEAT(OV5_RADIX_GTSE)) 1327 support->radix_gtse = !prom_radix_gtse_disable; 1328 break; 1329 case OV5_INDX(OV5_XIVE_SUPPORT): /* Interrupt mode */ 1330 prom_parse_xive_model(val & OV5_FEAT(OV5_XIVE_SUPPORT), 1331 support); 1332 break; 1333 } 1334 } 1335 1336 static void __init prom_check_platform_support(void) 1337 { 1338 struct platform_support supported = { 1339 .hash_mmu = false, 1340 .radix_mmu = false, 1341 .radix_gtse = false, 1342 .xive = false 1343 }; 1344 int prop_len = prom_getproplen(prom.chosen, 1345 "ibm,arch-vec-5-platform-support"); 1346 1347 /* 1348 * First copy the architecture vec template 1349 * 1350 * use memcpy() instead of *vec = *vec_template so that GCC replaces it 1351 * by __memcpy() when KASAN is active 1352 */ 1353 memcpy(&ibm_architecture_vec, &ibm_architecture_vec_template, 1354 sizeof(ibm_architecture_vec)); 1355 1356 prom_strscpy_pad(ibm_architecture_vec.vec7.os_id, linux_banner, 256); 1357 1358 if (prop_len > 1) { 1359 int i; 1360 u8 vec[8]; 1361 prom_debug("Found ibm,arch-vec-5-platform-support, len: %d\n", 1362 prop_len); 1363 if (prop_len > sizeof(vec)) 1364 prom_printf("WARNING: ibm,arch-vec-5-platform-support longer than expected (len: %d)\n", 1365 prop_len); 1366 prom_getprop(prom.chosen, "ibm,arch-vec-5-platform-support", &vec, sizeof(vec)); 1367 for (i = 0; i < prop_len; i += 2) { 1368 prom_debug("%d: index = 0x%x val = 0x%x\n", i / 2, vec[i], vec[i + 1]); 1369 prom_parse_platform_support(vec[i], vec[i + 1], &supported); 1370 } 1371 } 1372 1373 if (supported.radix_mmu && IS_ENABLED(CONFIG_PPC_RADIX_MMU)) { 1374 /* Radix preferred - Check if GTSE is also supported */ 1375 prom_debug("Asking for radix\n"); 1376 ibm_architecture_vec.vec5.mmu = OV5_FEAT(OV5_MMU_RADIX); 1377 if (supported.radix_gtse) 1378 ibm_architecture_vec.vec5.radix_ext = 1379 OV5_FEAT(OV5_RADIX_GTSE); 1380 else 1381 prom_debug("Radix GTSE isn't supported\n"); 1382 } else if (supported.hash_mmu) { 1383 /* Default to hash mmu (if we can) */ 1384 prom_debug("Asking for hash\n"); 1385 ibm_architecture_vec.vec5.mmu = OV5_FEAT(OV5_MMU_HASH); 1386 } else { 1387 /* We're probably on a legacy hypervisor */ 1388 prom_debug("Assuming legacy hash support\n"); 1389 } 1390 1391 if (supported.xive) { 1392 prom_debug("Asking for XIVE\n"); 1393 ibm_architecture_vec.vec5.intarch = OV5_FEAT(OV5_XIVE_EXPLOIT); 1394 } 1395 } 1396 1397 static void __init prom_send_capabilities(void) 1398 { 1399 ihandle root; 1400 prom_arg_t ret; 1401 u32 cores; 1402 1403 /* Check ibm,arch-vec-5-platform-support and fixup vec5 if required */ 1404 prom_check_platform_support(); 1405 1406 root = call_prom("open", 1, 1, ADDR("/")); 1407 if (root != 0) { 1408 /* We need to tell the FW about the number of cores we support. 1409 * 1410 * To do that, we count the number of threads on the first core 1411 * (we assume this is the same for all cores) and use it to 1412 * divide NR_CPUS. 1413 */ 1414 1415 cores = DIV_ROUND_UP(NR_CPUS, prom_count_smt_threads()); 1416 prom_printf("Max number of cores passed to firmware: %u (NR_CPUS = %d)\n", 1417 cores, NR_CPUS); 1418 1419 ibm_architecture_vec.vec5.max_cpus = cpu_to_be32(cores); 1420 1421 /* try calling the ibm,client-architecture-support method */ 1422 prom_printf("Calling ibm,client-architecture-support..."); 1423 if (call_prom_ret("call-method", 3, 2, &ret, 1424 ADDR("ibm,client-architecture-support"), 1425 root, 1426 ADDR(&ibm_architecture_vec)) == 0) { 1427 /* the call exists... */ 1428 if (ret) 1429 prom_printf("\nWARNING: ibm,client-architecture" 1430 "-support call FAILED!\n"); 1431 call_prom("close", 1, 0, root); 1432 prom_printf(" done\n"); 1433 return; 1434 } 1435 call_prom("close", 1, 0, root); 1436 prom_printf(" not implemented\n"); 1437 } 1438 1439 #ifdef __BIG_ENDIAN__ 1440 { 1441 ihandle elfloader; 1442 1443 /* no ibm,client-architecture-support call, try the old way */ 1444 elfloader = call_prom("open", 1, 1, 1445 ADDR("/packages/elf-loader")); 1446 if (elfloader == 0) { 1447 prom_printf("couldn't open /packages/elf-loader\n"); 1448 return; 1449 } 1450 call_prom("call-method", 3, 1, ADDR("process-elf-header"), 1451 elfloader, ADDR(&fake_elf)); 1452 call_prom("close", 1, 0, elfloader); 1453 } 1454 #endif /* __BIG_ENDIAN__ */ 1455 } 1456 #endif /* CONFIG_PPC_PSERIES */ 1457 1458 /* 1459 * Memory allocation strategy... our layout is normally: 1460 * 1461 * at 14Mb or more we have vmlinux, then a gap and initrd. In some 1462 * rare cases, initrd might end up being before the kernel though. 1463 * We assume this won't override the final kernel at 0, we have no 1464 * provision to handle that in this version, but it should hopefully 1465 * never happen. 1466 * 1467 * alloc_top is set to the top of RMO, eventually shrink down if the 1468 * TCEs overlap 1469 * 1470 * alloc_bottom is set to the top of kernel/initrd 1471 * 1472 * from there, allocations are done this way : rtas is allocated 1473 * topmost, and the device-tree is allocated from the bottom. We try 1474 * to grow the device-tree allocation as we progress. If we can't, 1475 * then we fail, we don't currently have a facility to restart 1476 * elsewhere, but that shouldn't be necessary. 1477 * 1478 * Note that calls to reserve_mem have to be done explicitly, memory 1479 * allocated with either alloc_up or alloc_down isn't automatically 1480 * reserved. 1481 */ 1482 1483 1484 /* 1485 * Allocates memory in the RMO upward from the kernel/initrd 1486 * 1487 * When align is 0, this is a special case, it means to allocate in place 1488 * at the current location of alloc_bottom or fail (that is basically 1489 * extending the previous allocation). Used for the device-tree flattening 1490 */ 1491 static unsigned long __init alloc_up(unsigned long size, unsigned long align) 1492 { 1493 unsigned long base = alloc_bottom; 1494 unsigned long addr = 0; 1495 1496 if (align) 1497 base = ALIGN(base, align); 1498 prom_debug("%s(%lx, %lx)\n", __func__, size, align); 1499 if (ram_top == 0) 1500 prom_panic("alloc_up() called with mem not initialized\n"); 1501 1502 if (align) 1503 base = ALIGN(alloc_bottom, align); 1504 else 1505 base = alloc_bottom; 1506 1507 for(; (base + size) <= alloc_top; 1508 base = ALIGN(base + 0x100000, align)) { 1509 prom_debug(" trying: 0x%lx\n\r", base); 1510 addr = (unsigned long)prom_claim(base, size, 0); 1511 if (addr != PROM_ERROR && addr != 0) 1512 break; 1513 addr = 0; 1514 if (align == 0) 1515 break; 1516 } 1517 if (addr == 0) 1518 return 0; 1519 alloc_bottom = addr + size; 1520 1521 prom_debug(" -> %lx\n", addr); 1522 prom_debug(" alloc_bottom : %lx\n", alloc_bottom); 1523 prom_debug(" alloc_top : %lx\n", alloc_top); 1524 prom_debug(" alloc_top_hi : %lx\n", alloc_top_high); 1525 prom_debug(" rmo_top : %lx\n", rmo_top); 1526 prom_debug(" ram_top : %lx\n", ram_top); 1527 1528 return addr; 1529 } 1530 1531 /* 1532 * Allocates memory downward, either from top of RMO, or if highmem 1533 * is set, from the top of RAM. Note that this one doesn't handle 1534 * failures. It does claim memory if highmem is not set. 1535 */ 1536 static unsigned long __init alloc_down(unsigned long size, unsigned long align, 1537 int highmem) 1538 { 1539 unsigned long base, addr = 0; 1540 1541 prom_debug("%s(%lx, %lx, %s)\n", __func__, size, align, 1542 highmem ? "(high)" : "(low)"); 1543 if (ram_top == 0) 1544 prom_panic("alloc_down() called with mem not initialized\n"); 1545 1546 if (highmem) { 1547 /* Carve out storage for the TCE table. */ 1548 addr = ALIGN_DOWN(alloc_top_high - size, align); 1549 if (addr <= alloc_bottom) 1550 return 0; 1551 /* Will we bump into the RMO ? If yes, check out that we 1552 * didn't overlap existing allocations there, if we did, 1553 * we are dead, we must be the first in town ! 1554 */ 1555 if (addr < rmo_top) { 1556 /* Good, we are first */ 1557 if (alloc_top == rmo_top) 1558 alloc_top = rmo_top = addr; 1559 else 1560 return 0; 1561 } 1562 alloc_top_high = addr; 1563 goto bail; 1564 } 1565 1566 base = ALIGN_DOWN(alloc_top - size, align); 1567 for (; base > alloc_bottom; 1568 base = ALIGN_DOWN(base - 0x100000, align)) { 1569 prom_debug(" trying: 0x%lx\n\r", base); 1570 addr = (unsigned long)prom_claim(base, size, 0); 1571 if (addr != PROM_ERROR && addr != 0) 1572 break; 1573 addr = 0; 1574 } 1575 if (addr == 0) 1576 return 0; 1577 alloc_top = addr; 1578 1579 bail: 1580 prom_debug(" -> %lx\n", addr); 1581 prom_debug(" alloc_bottom : %lx\n", alloc_bottom); 1582 prom_debug(" alloc_top : %lx\n", alloc_top); 1583 prom_debug(" alloc_top_hi : %lx\n", alloc_top_high); 1584 prom_debug(" rmo_top : %lx\n", rmo_top); 1585 prom_debug(" ram_top : %lx\n", ram_top); 1586 1587 return addr; 1588 } 1589 1590 /* 1591 * Parse a "reg" cell 1592 */ 1593 static unsigned long __init prom_next_cell(int s, cell_t **cellp) 1594 { 1595 cell_t *p = *cellp; 1596 unsigned long r = 0; 1597 1598 /* Ignore more than 2 cells */ 1599 while (s > sizeof(unsigned long) / 4) { 1600 p++; 1601 s--; 1602 } 1603 r = be32_to_cpu(*p++); 1604 #ifdef CONFIG_PPC64 1605 if (s > 1) { 1606 r <<= 32; 1607 r |= be32_to_cpu(*(p++)); 1608 } 1609 #endif 1610 *cellp = p; 1611 return r; 1612 } 1613 1614 /* 1615 * Very dumb function for adding to the memory reserve list, but 1616 * we don't need anything smarter at this point 1617 * 1618 * XXX Eventually check for collisions. They should NEVER happen. 1619 * If problems seem to show up, it would be a good start to track 1620 * them down. 1621 */ 1622 static void __init reserve_mem(u64 base, u64 size) 1623 { 1624 u64 top = base + size; 1625 unsigned long cnt = mem_reserve_cnt; 1626 1627 if (size == 0) 1628 return; 1629 1630 /* We need to always keep one empty entry so that we 1631 * have our terminator with "size" set to 0 since we are 1632 * dumb and just copy this entire array to the boot params 1633 */ 1634 base = ALIGN_DOWN(base, PAGE_SIZE); 1635 top = ALIGN(top, PAGE_SIZE); 1636 size = top - base; 1637 1638 if (cnt >= (MEM_RESERVE_MAP_SIZE - 1)) 1639 prom_panic("Memory reserve map exhausted !\n"); 1640 mem_reserve_map[cnt].base = cpu_to_be64(base); 1641 mem_reserve_map[cnt].size = cpu_to_be64(size); 1642 mem_reserve_cnt = cnt + 1; 1643 } 1644 1645 /* 1646 * Initialize memory allocation mechanism, parse "memory" nodes and 1647 * obtain that way the top of memory and RMO to setup out local allocator 1648 */ 1649 static void __init prom_init_mem(void) 1650 { 1651 phandle node; 1652 char type[64]; 1653 unsigned int plen; 1654 cell_t *p, *endp; 1655 __be32 val; 1656 u32 rac, rsc; 1657 1658 /* 1659 * We iterate the memory nodes to find 1660 * 1) top of RMO (first node) 1661 * 2) top of memory 1662 */ 1663 val = cpu_to_be32(2); 1664 prom_getprop(prom.root, "#address-cells", &val, sizeof(val)); 1665 rac = be32_to_cpu(val); 1666 val = cpu_to_be32(1); 1667 prom_getprop(prom.root, "#size-cells", &val, sizeof(rsc)); 1668 rsc = be32_to_cpu(val); 1669 prom_debug("root_addr_cells: %x\n", rac); 1670 prom_debug("root_size_cells: %x\n", rsc); 1671 1672 prom_debug("scanning memory:\n"); 1673 1674 for (node = 0; prom_next_node(&node); ) { 1675 type[0] = 0; 1676 prom_getprop(node, "device_type", type, sizeof(type)); 1677 1678 if (type[0] == 0) { 1679 /* 1680 * CHRP Longtrail machines have no device_type 1681 * on the memory node, so check the name instead... 1682 */ 1683 prom_getprop(node, "name", type, sizeof(type)); 1684 } 1685 if (prom_strcmp(type, "memory")) 1686 continue; 1687 1688 plen = prom_getprop(node, "reg", regbuf, sizeof(regbuf)); 1689 if (plen > sizeof(regbuf)) { 1690 prom_printf("memory node too large for buffer !\n"); 1691 plen = sizeof(regbuf); 1692 } 1693 p = regbuf; 1694 endp = p + (plen / sizeof(cell_t)); 1695 1696 #ifdef DEBUG_PROM 1697 memset(prom_scratch, 0, sizeof(prom_scratch)); 1698 call_prom("package-to-path", 3, 1, node, prom_scratch, 1699 sizeof(prom_scratch) - 1); 1700 prom_debug(" node %s :\n", prom_scratch); 1701 #endif /* DEBUG_PROM */ 1702 1703 while ((endp - p) >= (rac + rsc)) { 1704 unsigned long base, size; 1705 1706 base = prom_next_cell(rac, &p); 1707 size = prom_next_cell(rsc, &p); 1708 1709 if (size == 0) 1710 continue; 1711 prom_debug(" %lx %lx\n", base, size); 1712 if (base == 0 && (of_platform & PLATFORM_LPAR)) 1713 rmo_top = size; 1714 if ((base + size) > ram_top) 1715 ram_top = base + size; 1716 } 1717 } 1718 1719 alloc_bottom = PAGE_ALIGN((unsigned long)&_end + 0x4000); 1720 1721 /* 1722 * If prom_memory_limit is set we reduce the upper limits *except* for 1723 * alloc_top_high. This must be the real top of RAM so we can put 1724 * TCE's up there. 1725 */ 1726 1727 alloc_top_high = ram_top; 1728 1729 if (prom_memory_limit) { 1730 if (prom_memory_limit <= alloc_bottom) { 1731 prom_printf("Ignoring mem=%lx <= alloc_bottom.\n", 1732 prom_memory_limit); 1733 prom_memory_limit = 0; 1734 } else if (prom_memory_limit >= ram_top) { 1735 prom_printf("Ignoring mem=%lx >= ram_top.\n", 1736 prom_memory_limit); 1737 prom_memory_limit = 0; 1738 } else { 1739 ram_top = prom_memory_limit; 1740 rmo_top = min(rmo_top, prom_memory_limit); 1741 } 1742 } 1743 1744 /* 1745 * Setup our top alloc point, that is top of RMO or top of 1746 * segment 0 when running non-LPAR. 1747 * Some RS64 machines have buggy firmware where claims up at 1748 * 1GB fail. Cap at 768MB as a workaround. 1749 * Since 768MB is plenty of room, and we need to cap to something 1750 * reasonable on 32-bit, cap at 768MB on all machines. 1751 */ 1752 if (!rmo_top) 1753 rmo_top = ram_top; 1754 rmo_top = min(0x30000000ul, rmo_top); 1755 alloc_top = rmo_top; 1756 alloc_top_high = ram_top; 1757 1758 /* 1759 * Check if we have an initrd after the kernel but still inside 1760 * the RMO. If we do move our bottom point to after it. 1761 */ 1762 if (prom_initrd_start && 1763 prom_initrd_start < rmo_top && 1764 prom_initrd_end > alloc_bottom) 1765 alloc_bottom = PAGE_ALIGN(prom_initrd_end); 1766 1767 prom_printf("memory layout at init:\n"); 1768 prom_printf(" memory_limit : %lx (16 MB aligned)\n", 1769 prom_memory_limit); 1770 prom_printf(" alloc_bottom : %lx\n", alloc_bottom); 1771 prom_printf(" alloc_top : %lx\n", alloc_top); 1772 prom_printf(" alloc_top_hi : %lx\n", alloc_top_high); 1773 prom_printf(" rmo_top : %lx\n", rmo_top); 1774 prom_printf(" ram_top : %lx\n", ram_top); 1775 } 1776 1777 static void __init prom_close_stdin(void) 1778 { 1779 __be32 val; 1780 ihandle stdin; 1781 1782 if (prom_getprop(prom.chosen, "stdin", &val, sizeof(val)) > 0) { 1783 stdin = be32_to_cpu(val); 1784 call_prom("close", 1, 0, stdin); 1785 } 1786 } 1787 1788 #ifdef CONFIG_PPC_SVM 1789 static int __init prom_rtas_hcall(uint64_t args) 1790 { 1791 register uint64_t arg1 asm("r3") = H_RTAS; 1792 register uint64_t arg2 asm("r4") = args; 1793 1794 asm volatile("sc 1\n" : "=r" (arg1) : 1795 "r" (arg1), 1796 "r" (arg2) :); 1797 srr_regs_clobbered(); 1798 1799 return arg1; 1800 } 1801 1802 static struct rtas_args __prombss os_term_args; 1803 1804 static void __init prom_rtas_os_term(char *str) 1805 { 1806 phandle rtas_node; 1807 __be32 val; 1808 u32 token; 1809 1810 prom_debug("%s: start...\n", __func__); 1811 rtas_node = call_prom("finddevice", 1, 1, ADDR("/rtas")); 1812 prom_debug("rtas_node: %x\n", rtas_node); 1813 if (!PHANDLE_VALID(rtas_node)) 1814 return; 1815 1816 val = 0; 1817 prom_getprop(rtas_node, "ibm,os-term", &val, sizeof(val)); 1818 token = be32_to_cpu(val); 1819 prom_debug("ibm,os-term: %x\n", token); 1820 if (token == 0) 1821 prom_panic("Could not get token for ibm,os-term\n"); 1822 os_term_args.token = cpu_to_be32(token); 1823 os_term_args.nargs = cpu_to_be32(1); 1824 os_term_args.nret = cpu_to_be32(1); 1825 os_term_args.args[0] = cpu_to_be32(__pa(str)); 1826 prom_rtas_hcall((uint64_t)&os_term_args); 1827 } 1828 #endif /* CONFIG_PPC_SVM */ 1829 1830 /* 1831 * Allocate room for and instantiate RTAS 1832 */ 1833 static void __init prom_instantiate_rtas(void) 1834 { 1835 phandle rtas_node; 1836 ihandle rtas_inst; 1837 u32 base, entry = 0; 1838 __be32 val; 1839 u32 size = 0; 1840 1841 prom_debug("prom_instantiate_rtas: start...\n"); 1842 1843 rtas_node = call_prom("finddevice", 1, 1, ADDR("/rtas")); 1844 prom_debug("rtas_node: %x\n", rtas_node); 1845 if (!PHANDLE_VALID(rtas_node)) 1846 return; 1847 1848 val = 0; 1849 prom_getprop(rtas_node, "rtas-size", &val, sizeof(size)); 1850 size = be32_to_cpu(val); 1851 if (size == 0) 1852 return; 1853 1854 base = alloc_down(size, PAGE_SIZE, 0); 1855 if (base == 0) 1856 prom_panic("Could not allocate memory for RTAS\n"); 1857 1858 rtas_inst = call_prom("open", 1, 1, ADDR("/rtas")); 1859 if (!IHANDLE_VALID(rtas_inst)) { 1860 prom_printf("opening rtas package failed (%x)\n", rtas_inst); 1861 return; 1862 } 1863 1864 prom_printf("instantiating rtas at 0x%x...", base); 1865 1866 if (call_prom_ret("call-method", 3, 2, &entry, 1867 ADDR("instantiate-rtas"), 1868 rtas_inst, base) != 0 1869 || entry == 0) { 1870 prom_printf(" failed\n"); 1871 return; 1872 } 1873 prom_printf(" done\n"); 1874 1875 reserve_mem(base, size); 1876 1877 val = cpu_to_be32(base); 1878 prom_setprop(rtas_node, "/rtas", "linux,rtas-base", 1879 &val, sizeof(val)); 1880 val = cpu_to_be32(entry); 1881 prom_setprop(rtas_node, "/rtas", "linux,rtas-entry", 1882 &val, sizeof(val)); 1883 1884 /* Check if it supports "query-cpu-stopped-state" */ 1885 if (prom_getprop(rtas_node, "query-cpu-stopped-state", 1886 &val, sizeof(val)) != PROM_ERROR) 1887 rtas_has_query_cpu_stopped = true; 1888 1889 prom_debug("rtas base = 0x%x\n", base); 1890 prom_debug("rtas entry = 0x%x\n", entry); 1891 prom_debug("rtas size = 0x%x\n", size); 1892 1893 prom_debug("prom_instantiate_rtas: end...\n"); 1894 } 1895 1896 #ifdef CONFIG_PPC64 1897 /* 1898 * Allocate room for and instantiate Stored Measurement Log (SML) 1899 */ 1900 static void __init prom_instantiate_sml(void) 1901 { 1902 phandle ibmvtpm_node; 1903 ihandle ibmvtpm_inst; 1904 u32 entry = 0, size = 0, succ = 0; 1905 u64 base; 1906 __be32 val; 1907 1908 prom_debug("prom_instantiate_sml: start...\n"); 1909 1910 ibmvtpm_node = call_prom("finddevice", 1, 1, ADDR("/vdevice/vtpm")); 1911 prom_debug("ibmvtpm_node: %x\n", ibmvtpm_node); 1912 if (!PHANDLE_VALID(ibmvtpm_node)) 1913 return; 1914 1915 ibmvtpm_inst = call_prom("open", 1, 1, ADDR("/vdevice/vtpm")); 1916 if (!IHANDLE_VALID(ibmvtpm_inst)) { 1917 prom_printf("opening vtpm package failed (%x)\n", ibmvtpm_inst); 1918 return; 1919 } 1920 1921 if (prom_getprop(ibmvtpm_node, "ibm,sml-efi-reformat-supported", 1922 &val, sizeof(val)) != PROM_ERROR) { 1923 if (call_prom_ret("call-method", 2, 2, &succ, 1924 ADDR("reformat-sml-to-efi-alignment"), 1925 ibmvtpm_inst) != 0 || succ == 0) { 1926 prom_printf("Reformat SML to EFI alignment failed\n"); 1927 return; 1928 } 1929 1930 if (call_prom_ret("call-method", 2, 2, &size, 1931 ADDR("sml-get-allocated-size"), 1932 ibmvtpm_inst) != 0 || size == 0) { 1933 prom_printf("SML get allocated size failed\n"); 1934 return; 1935 } 1936 } else { 1937 if (call_prom_ret("call-method", 2, 2, &size, 1938 ADDR("sml-get-handover-size"), 1939 ibmvtpm_inst) != 0 || size == 0) { 1940 prom_printf("SML get handover size failed\n"); 1941 return; 1942 } 1943 } 1944 1945 base = alloc_down(size, PAGE_SIZE, 0); 1946 if (base == 0) 1947 prom_panic("Could not allocate memory for sml\n"); 1948 1949 prom_printf("instantiating sml at 0x%llx...", base); 1950 1951 memset((void *)base, 0, size); 1952 1953 if (call_prom_ret("call-method", 4, 2, &entry, 1954 ADDR("sml-handover"), 1955 ibmvtpm_inst, size, base) != 0 || entry == 0) { 1956 prom_printf("SML handover failed\n"); 1957 return; 1958 } 1959 prom_printf(" done\n"); 1960 1961 reserve_mem(base, size); 1962 1963 prom_setprop(ibmvtpm_node, "/vdevice/vtpm", "linux,sml-base", 1964 &base, sizeof(base)); 1965 prom_setprop(ibmvtpm_node, "/vdevice/vtpm", "linux,sml-size", 1966 &size, sizeof(size)); 1967 1968 prom_debug("sml base = 0x%llx\n", base); 1969 prom_debug("sml size = 0x%x\n", size); 1970 1971 prom_debug("prom_instantiate_sml: end...\n"); 1972 } 1973 1974 /* 1975 * Allocate room for and initialize TCE tables 1976 */ 1977 #ifdef __BIG_ENDIAN__ 1978 static void __init prom_initialize_tce_table(void) 1979 { 1980 phandle node; 1981 ihandle phb_node; 1982 char compatible[64], type[64], model[64]; 1983 char *path = prom_scratch; 1984 u64 base, align; 1985 u32 minalign, minsize; 1986 u64 tce_entry, *tce_entryp; 1987 u64 local_alloc_top, local_alloc_bottom; 1988 u64 i; 1989 1990 if (prom_iommu_off) 1991 return; 1992 1993 prom_debug("starting prom_initialize_tce_table\n"); 1994 1995 /* Cache current top of allocs so we reserve a single block */ 1996 local_alloc_top = alloc_top_high; 1997 local_alloc_bottom = local_alloc_top; 1998 1999 /* Search all nodes looking for PHBs. */ 2000 for (node = 0; prom_next_node(&node); ) { 2001 compatible[0] = 0; 2002 type[0] = 0; 2003 model[0] = 0; 2004 prom_getprop(node, "compatible", 2005 compatible, sizeof(compatible)); 2006 prom_getprop(node, "device_type", type, sizeof(type)); 2007 prom_getprop(node, "model", model, sizeof(model)); 2008 2009 if ((type[0] == 0) || (prom_strstr(type, "pci") == NULL)) 2010 continue; 2011 2012 /* Keep the old logic intact to avoid regression. */ 2013 if (compatible[0] != 0) { 2014 if ((prom_strstr(compatible, "python") == NULL) && 2015 (prom_strstr(compatible, "Speedwagon") == NULL) && 2016 (prom_strstr(compatible, "Winnipeg") == NULL)) 2017 continue; 2018 } else if (model[0] != 0) { 2019 if ((prom_strstr(model, "ython") == NULL) && 2020 (prom_strstr(model, "peedwagon") == NULL) && 2021 (prom_strstr(model, "innipeg") == NULL)) 2022 continue; 2023 } 2024 2025 if (prom_getprop(node, "tce-table-minalign", &minalign, 2026 sizeof(minalign)) == PROM_ERROR) 2027 minalign = 0; 2028 if (prom_getprop(node, "tce-table-minsize", &minsize, 2029 sizeof(minsize)) == PROM_ERROR) 2030 minsize = 4UL << 20; 2031 2032 /* 2033 * Even though we read what OF wants, we just set the table 2034 * size to 4 MB. This is enough to map 2GB of PCI DMA space. 2035 * By doing this, we avoid the pitfalls of trying to DMA to 2036 * MMIO space and the DMA alias hole. 2037 */ 2038 minsize = 4UL << 20; 2039 2040 /* Align to the greater of the align or size */ 2041 align = max(minalign, minsize); 2042 base = alloc_down(minsize, align, 1); 2043 if (base == 0) 2044 prom_panic("ERROR, cannot find space for TCE table.\n"); 2045 if (base < local_alloc_bottom) 2046 local_alloc_bottom = base; 2047 2048 /* It seems OF doesn't null-terminate the path :-( */ 2049 memset(path, 0, sizeof(prom_scratch)); 2050 /* Call OF to setup the TCE hardware */ 2051 if (call_prom("package-to-path", 3, 1, node, 2052 path, sizeof(prom_scratch) - 1) == PROM_ERROR) { 2053 prom_printf("package-to-path failed\n"); 2054 } 2055 2056 /* Save away the TCE table attributes for later use. */ 2057 prom_setprop(node, path, "linux,tce-base", &base, sizeof(base)); 2058 prom_setprop(node, path, "linux,tce-size", &minsize, sizeof(minsize)); 2059 2060 prom_debug("TCE table: %s\n", path); 2061 prom_debug("\tnode = 0x%x\n", node); 2062 prom_debug("\tbase = 0x%llx\n", base); 2063 prom_debug("\tsize = 0x%x\n", minsize); 2064 2065 /* Initialize the table to have a one-to-one mapping 2066 * over the allocated size. 2067 */ 2068 tce_entryp = (u64 *)base; 2069 for (i = 0; i < (minsize >> 3) ;tce_entryp++, i++) { 2070 tce_entry = (i << PAGE_SHIFT); 2071 tce_entry |= 0x3; 2072 *tce_entryp = tce_entry; 2073 } 2074 2075 prom_printf("opening PHB %s", path); 2076 phb_node = call_prom("open", 1, 1, path); 2077 if (phb_node == 0) 2078 prom_printf("... failed\n"); 2079 else 2080 prom_printf("... done\n"); 2081 2082 call_prom("call-method", 6, 0, ADDR("set-64-bit-addressing"), 2083 phb_node, -1, minsize, 2084 (u32) base, (u32) (base >> 32)); 2085 call_prom("close", 1, 0, phb_node); 2086 } 2087 2088 reserve_mem(local_alloc_bottom, local_alloc_top - local_alloc_bottom); 2089 2090 /* These are only really needed if there is a memory limit in 2091 * effect, but we don't know so export them always. */ 2092 prom_tce_alloc_start = local_alloc_bottom; 2093 prom_tce_alloc_end = local_alloc_top; 2094 2095 /* Flag the first invalid entry */ 2096 prom_debug("ending prom_initialize_tce_table\n"); 2097 } 2098 #endif /* __BIG_ENDIAN__ */ 2099 #endif /* CONFIG_PPC64 */ 2100 2101 /* 2102 * With CHRP SMP we need to use the OF to start the other processors. 2103 * We can't wait until smp_boot_cpus (the OF is trashed by then) 2104 * so we have to put the processors into a holding pattern controlled 2105 * by the kernel (not OF) before we destroy the OF. 2106 * 2107 * This uses a chunk of low memory, puts some holding pattern 2108 * code there and sends the other processors off to there until 2109 * smp_boot_cpus tells them to do something. The holding pattern 2110 * checks that address until its cpu # is there, when it is that 2111 * cpu jumps to __secondary_start(). smp_boot_cpus() takes care 2112 * of setting those values. 2113 * 2114 * We also use physical address 0x4 here to tell when a cpu 2115 * is in its holding pattern code. 2116 * 2117 * -- Cort 2118 */ 2119 /* 2120 * We want to reference the copy of __secondary_hold_* in the 2121 * 0 - 0x100 address range 2122 */ 2123 #define LOW_ADDR(x) (((unsigned long) &(x)) & 0xff) 2124 2125 static void __init prom_hold_cpus(void) 2126 { 2127 unsigned long i; 2128 phandle node; 2129 char type[64]; 2130 unsigned long *spinloop 2131 = (void *) LOW_ADDR(__secondary_hold_spinloop); 2132 unsigned long *acknowledge 2133 = (void *) LOW_ADDR(__secondary_hold_acknowledge); 2134 unsigned long secondary_hold = LOW_ADDR(__secondary_hold); 2135 2136 /* 2137 * On pseries, if RTAS supports "query-cpu-stopped-state", 2138 * we skip this stage, the CPUs will be started by the 2139 * kernel using RTAS. 2140 */ 2141 if ((of_platform == PLATFORM_PSERIES || 2142 of_platform == PLATFORM_PSERIES_LPAR) && 2143 rtas_has_query_cpu_stopped) { 2144 prom_printf("prom_hold_cpus: skipped\n"); 2145 return; 2146 } 2147 2148 prom_debug("prom_hold_cpus: start...\n"); 2149 prom_debug(" 1) spinloop = 0x%lx\n", (unsigned long)spinloop); 2150 prom_debug(" 1) *spinloop = 0x%lx\n", *spinloop); 2151 prom_debug(" 1) acknowledge = 0x%lx\n", 2152 (unsigned long)acknowledge); 2153 prom_debug(" 1) *acknowledge = 0x%lx\n", *acknowledge); 2154 prom_debug(" 1) secondary_hold = 0x%lx\n", secondary_hold); 2155 2156 /* Set the common spinloop variable, so all of the secondary cpus 2157 * will block when they are awakened from their OF spinloop. 2158 * This must occur for both SMP and non SMP kernels, since OF will 2159 * be trashed when we move the kernel. 2160 */ 2161 *spinloop = 0; 2162 2163 /* look for cpus */ 2164 for (node = 0; prom_next_node(&node); ) { 2165 unsigned int cpu_no; 2166 __be32 reg; 2167 2168 type[0] = 0; 2169 prom_getprop(node, "device_type", type, sizeof(type)); 2170 if (prom_strcmp(type, "cpu") != 0) 2171 continue; 2172 2173 /* Skip non-configured cpus. */ 2174 if (prom_getprop(node, "status", type, sizeof(type)) > 0) 2175 if (prom_strcmp(type, "okay") != 0) 2176 continue; 2177 2178 reg = cpu_to_be32(-1); /* make sparse happy */ 2179 prom_getprop(node, "reg", ®, sizeof(reg)); 2180 cpu_no = be32_to_cpu(reg); 2181 2182 prom_debug("cpu hw idx = %u\n", cpu_no); 2183 2184 /* Init the acknowledge var which will be reset by 2185 * the secondary cpu when it awakens from its OF 2186 * spinloop. 2187 */ 2188 *acknowledge = (unsigned long)-1; 2189 2190 if (cpu_no != prom.cpu) { 2191 /* Primary Thread of non-boot cpu or any thread */ 2192 prom_printf("starting cpu hw idx %u... ", cpu_no); 2193 call_prom("start-cpu", 3, 0, node, 2194 secondary_hold, cpu_no); 2195 2196 for (i = 0; (i < 100000000) && 2197 (*acknowledge == ((unsigned long)-1)); i++ ) 2198 mb(); 2199 2200 if (*acknowledge == cpu_no) 2201 prom_printf("done\n"); 2202 else 2203 prom_printf("failed: %lx\n", *acknowledge); 2204 } 2205 #ifdef CONFIG_SMP 2206 else 2207 prom_printf("boot cpu hw idx %u\n", cpu_no); 2208 #endif /* CONFIG_SMP */ 2209 } 2210 2211 prom_debug("prom_hold_cpus: end...\n"); 2212 } 2213 2214 2215 static void __init prom_init_client_services(unsigned long pp) 2216 { 2217 /* Get a handle to the prom entry point before anything else */ 2218 prom_entry = pp; 2219 2220 /* get a handle for the stdout device */ 2221 prom.chosen = call_prom("finddevice", 1, 1, ADDR("/chosen")); 2222 if (!PHANDLE_VALID(prom.chosen)) 2223 prom_panic("cannot find chosen"); /* msg won't be printed :( */ 2224 2225 /* get device tree root */ 2226 prom.root = call_prom("finddevice", 1, 1, ADDR("/")); 2227 if (!PHANDLE_VALID(prom.root)) 2228 prom_panic("cannot find device tree root"); /* msg won't be printed :( */ 2229 2230 prom.mmumap = 0; 2231 } 2232 2233 #ifdef CONFIG_PPC32 2234 /* 2235 * For really old powermacs, we need to map things we claim. 2236 * For that, we need the ihandle of the mmu. 2237 * Also, on the longtrail, we need to work around other bugs. 2238 */ 2239 static void __init prom_find_mmu(void) 2240 { 2241 phandle oprom; 2242 char version[64]; 2243 2244 oprom = call_prom("finddevice", 1, 1, ADDR("/openprom")); 2245 if (!PHANDLE_VALID(oprom)) 2246 return; 2247 if (prom_getprop(oprom, "model", version, sizeof(version)) <= 0) 2248 return; 2249 version[sizeof(version) - 1] = 0; 2250 /* XXX might need to add other versions here */ 2251 if (prom_strcmp(version, "Open Firmware, 1.0.5") == 0) 2252 of_workarounds = OF_WA_CLAIM; 2253 else if (prom_strncmp(version, "FirmWorks,3.", 12) == 0) { 2254 of_workarounds = OF_WA_CLAIM | OF_WA_LONGTRAIL; 2255 call_prom("interpret", 1, 1, "dev /memory 0 to allow-reclaim"); 2256 } else 2257 return; 2258 prom.memory = call_prom("open", 1, 1, ADDR("/memory")); 2259 prom_getprop(prom.chosen, "mmu", &prom.mmumap, 2260 sizeof(prom.mmumap)); 2261 prom.mmumap = be32_to_cpu(prom.mmumap); 2262 if (!IHANDLE_VALID(prom.memory) || !IHANDLE_VALID(prom.mmumap)) 2263 of_workarounds &= ~OF_WA_CLAIM; /* hmmm */ 2264 } 2265 #else 2266 #define prom_find_mmu() 2267 #endif 2268 2269 static void __init prom_init_stdout(void) 2270 { 2271 char *path = of_stdout_device; 2272 char type[16]; 2273 phandle stdout_node; 2274 __be32 val; 2275 2276 if (prom_getprop(prom.chosen, "stdout", &val, sizeof(val)) <= 0) 2277 prom_panic("cannot find stdout"); 2278 2279 prom.stdout = be32_to_cpu(val); 2280 2281 /* Get the full OF pathname of the stdout device */ 2282 memset(path, 0, 256); 2283 call_prom("instance-to-path", 3, 1, prom.stdout, path, 255); 2284 prom_printf("OF stdout device is: %s\n", of_stdout_device); 2285 prom_setprop(prom.chosen, "/chosen", "linux,stdout-path", 2286 path, prom_strlen(path) + 1); 2287 2288 /* instance-to-package fails on PA-Semi */ 2289 stdout_node = call_prom("instance-to-package", 1, 1, prom.stdout); 2290 if (stdout_node != PROM_ERROR) { 2291 val = cpu_to_be32(stdout_node); 2292 2293 /* If it's a display, note it */ 2294 memset(type, 0, sizeof(type)); 2295 prom_getprop(stdout_node, "device_type", type, sizeof(type)); 2296 if (prom_strcmp(type, "display") == 0) 2297 prom_setprop(stdout_node, path, "linux,boot-display", NULL, 0); 2298 } 2299 } 2300 2301 static int __init prom_find_machine_type(void) 2302 { 2303 char compat[256]; 2304 int len, i = 0; 2305 #ifdef CONFIG_PPC64 2306 phandle rtas; 2307 int x; 2308 #endif 2309 2310 /* Look for a PowerMac or a Cell */ 2311 len = prom_getprop(prom.root, "compatible", 2312 compat, sizeof(compat)-1); 2313 if (len > 0) { 2314 compat[len] = 0; 2315 while (i < len) { 2316 char *p = &compat[i]; 2317 int sl = prom_strlen(p); 2318 if (sl == 0) 2319 break; 2320 if (prom_strstr(p, "Power Macintosh") || 2321 prom_strstr(p, "MacRISC")) 2322 return PLATFORM_POWERMAC; 2323 #ifdef CONFIG_PPC64 2324 /* We must make sure we don't detect the IBM Cell 2325 * blades as pSeries due to some firmware issues, 2326 * so we do it here. 2327 */ 2328 if (prom_strstr(p, "IBM,CBEA") || 2329 prom_strstr(p, "IBM,CPBW-1.0")) 2330 return PLATFORM_GENERIC; 2331 #endif /* CONFIG_PPC64 */ 2332 i += sl + 1; 2333 } 2334 } 2335 #ifdef CONFIG_PPC64 2336 /* Try to figure out if it's an IBM pSeries or any other 2337 * PAPR compliant platform. We assume it is if : 2338 * - /device_type is "chrp" (please, do NOT use that for future 2339 * non-IBM designs ! 2340 * - it has /rtas 2341 */ 2342 len = prom_getprop(prom.root, "device_type", 2343 compat, sizeof(compat)-1); 2344 if (len <= 0) 2345 return PLATFORM_GENERIC; 2346 if (prom_strcmp(compat, "chrp")) 2347 return PLATFORM_GENERIC; 2348 2349 /* Default to pSeries. We need to know if we are running LPAR */ 2350 rtas = call_prom("finddevice", 1, 1, ADDR("/rtas")); 2351 if (!PHANDLE_VALID(rtas)) 2352 return PLATFORM_GENERIC; 2353 x = prom_getproplen(rtas, "ibm,hypertas-functions"); 2354 if (x != PROM_ERROR) { 2355 prom_debug("Hypertas detected, assuming LPAR !\n"); 2356 return PLATFORM_PSERIES_LPAR; 2357 } 2358 return PLATFORM_PSERIES; 2359 #else 2360 return PLATFORM_GENERIC; 2361 #endif 2362 } 2363 2364 static int __init prom_set_color(ihandle ih, int i, int r, int g, int b) 2365 { 2366 return call_prom("call-method", 6, 1, ADDR("color!"), ih, i, b, g, r); 2367 } 2368 2369 /* 2370 * If we have a display that we don't know how to drive, 2371 * we will want to try to execute OF's open method for it 2372 * later. However, OF will probably fall over if we do that 2373 * we've taken over the MMU. 2374 * So we check whether we will need to open the display, 2375 * and if so, open it now. 2376 */ 2377 static void __init prom_check_displays(void) 2378 { 2379 char type[16], *path; 2380 phandle node; 2381 ihandle ih; 2382 int i; 2383 2384 static const unsigned char default_colors[] __initconst = { 2385 0x00, 0x00, 0x00, 2386 0x00, 0x00, 0xaa, 2387 0x00, 0xaa, 0x00, 2388 0x00, 0xaa, 0xaa, 2389 0xaa, 0x00, 0x00, 2390 0xaa, 0x00, 0xaa, 2391 0xaa, 0xaa, 0x00, 2392 0xaa, 0xaa, 0xaa, 2393 0x55, 0x55, 0x55, 2394 0x55, 0x55, 0xff, 2395 0x55, 0xff, 0x55, 2396 0x55, 0xff, 0xff, 2397 0xff, 0x55, 0x55, 2398 0xff, 0x55, 0xff, 2399 0xff, 0xff, 0x55, 2400 0xff, 0xff, 0xff 2401 }; 2402 const unsigned char *clut; 2403 2404 prom_debug("Looking for displays\n"); 2405 for (node = 0; prom_next_node(&node); ) { 2406 memset(type, 0, sizeof(type)); 2407 prom_getprop(node, "device_type", type, sizeof(type)); 2408 if (prom_strcmp(type, "display") != 0) 2409 continue; 2410 2411 /* It seems OF doesn't null-terminate the path :-( */ 2412 path = prom_scratch; 2413 memset(path, 0, sizeof(prom_scratch)); 2414 2415 /* 2416 * leave some room at the end of the path for appending extra 2417 * arguments 2418 */ 2419 if (call_prom("package-to-path", 3, 1, node, path, 2420 sizeof(prom_scratch) - 10) == PROM_ERROR) 2421 continue; 2422 prom_printf("found display : %s, opening... ", path); 2423 2424 ih = call_prom("open", 1, 1, path); 2425 if (ih == 0) { 2426 prom_printf("failed\n"); 2427 continue; 2428 } 2429 2430 /* Success */ 2431 prom_printf("done\n"); 2432 prom_setprop(node, path, "linux,opened", NULL, 0); 2433 2434 /* Setup a usable color table when the appropriate 2435 * method is available. Should update this to set-colors */ 2436 clut = default_colors; 2437 for (i = 0; i < 16; i++, clut += 3) 2438 if (prom_set_color(ih, i, clut[0], clut[1], 2439 clut[2]) != 0) 2440 break; 2441 2442 #ifdef CONFIG_LOGO_LINUX_CLUT224 2443 clut = PTRRELOC(logo_linux_clut224.clut); 2444 for (i = 0; i < logo_linux_clut224.clutsize; i++, clut += 3) 2445 if (prom_set_color(ih, i + 32, clut[0], clut[1], 2446 clut[2]) != 0) 2447 break; 2448 #endif /* CONFIG_LOGO_LINUX_CLUT224 */ 2449 2450 #ifdef CONFIG_PPC_EARLY_DEBUG_BOOTX 2451 if (prom_getprop(node, "linux,boot-display", NULL, 0) != 2452 PROM_ERROR) { 2453 u32 width, height, pitch, addr; 2454 2455 prom_printf("Setting btext !\n"); 2456 2457 if (prom_getprop(node, "width", &width, 4) == PROM_ERROR) 2458 return; 2459 2460 if (prom_getprop(node, "height", &height, 4) == PROM_ERROR) 2461 return; 2462 2463 if (prom_getprop(node, "linebytes", &pitch, 4) == PROM_ERROR) 2464 return; 2465 2466 if (prom_getprop(node, "address", &addr, 4) == PROM_ERROR) 2467 return; 2468 2469 prom_printf("W=%d H=%d LB=%d addr=0x%x\n", 2470 width, height, pitch, addr); 2471 btext_setup_display(width, height, 8, pitch, addr); 2472 btext_prepare_BAT(); 2473 } 2474 #endif /* CONFIG_PPC_EARLY_DEBUG_BOOTX */ 2475 } 2476 } 2477 2478 2479 /* Return (relocated) pointer to this much memory: moves initrd if reqd. */ 2480 static void __init *make_room(unsigned long *mem_start, unsigned long *mem_end, 2481 unsigned long needed, unsigned long align) 2482 { 2483 void *ret; 2484 2485 *mem_start = ALIGN(*mem_start, align); 2486 while ((*mem_start + needed) > *mem_end) { 2487 unsigned long room, chunk; 2488 2489 prom_debug("Chunk exhausted, claiming more at %lx...\n", 2490 alloc_bottom); 2491 room = alloc_top - alloc_bottom; 2492 if (room > DEVTREE_CHUNK_SIZE) 2493 room = DEVTREE_CHUNK_SIZE; 2494 if (room < PAGE_SIZE) 2495 prom_panic("No memory for flatten_device_tree " 2496 "(no room)\n"); 2497 chunk = alloc_up(room, 0); 2498 if (chunk == 0) 2499 prom_panic("No memory for flatten_device_tree " 2500 "(claim failed)\n"); 2501 *mem_end = chunk + room; 2502 } 2503 2504 ret = (void *)*mem_start; 2505 *mem_start += needed; 2506 2507 return ret; 2508 } 2509 2510 #define dt_push_token(token, mem_start, mem_end) do { \ 2511 void *room = make_room(mem_start, mem_end, 4, 4); \ 2512 *(__be32 *)room = cpu_to_be32(token); \ 2513 } while(0) 2514 2515 static unsigned long __init dt_find_string(char *str) 2516 { 2517 char *s, *os; 2518 2519 s = os = (char *)dt_string_start; 2520 s += 4; 2521 while (s < (char *)dt_string_end) { 2522 if (prom_strcmp(s, str) == 0) 2523 return s - os; 2524 s += prom_strlen(s) + 1; 2525 } 2526 return 0; 2527 } 2528 2529 /* 2530 * The Open Firmware 1275 specification states properties must be 31 bytes or 2531 * less, however not all firmwares obey this. Make it 64 bytes to be safe. 2532 */ 2533 #define MAX_PROPERTY_NAME 64 2534 2535 static void __init scan_dt_build_strings(phandle node, 2536 unsigned long *mem_start, 2537 unsigned long *mem_end) 2538 { 2539 char *prev_name, *namep, *sstart; 2540 unsigned long soff; 2541 phandle child; 2542 2543 sstart = (char *)dt_string_start; 2544 2545 /* get and store all property names */ 2546 prev_name = ""; 2547 for (;;) { 2548 /* 64 is max len of name including nul. */ 2549 namep = make_room(mem_start, mem_end, MAX_PROPERTY_NAME, 1); 2550 if (call_prom("nextprop", 3, 1, node, prev_name, namep) != 1) { 2551 /* No more nodes: unwind alloc */ 2552 *mem_start = (unsigned long)namep; 2553 break; 2554 } 2555 2556 /* skip "name" */ 2557 if (prom_strcmp(namep, "name") == 0) { 2558 *mem_start = (unsigned long)namep; 2559 prev_name = "name"; 2560 continue; 2561 } 2562 /* get/create string entry */ 2563 soff = dt_find_string(namep); 2564 if (soff != 0) { 2565 *mem_start = (unsigned long)namep; 2566 namep = sstart + soff; 2567 } else { 2568 /* Trim off some if we can */ 2569 *mem_start = (unsigned long)namep + prom_strlen(namep) + 1; 2570 dt_string_end = *mem_start; 2571 } 2572 prev_name = namep; 2573 } 2574 2575 /* do all our children */ 2576 child = call_prom("child", 1, 1, node); 2577 while (child != 0) { 2578 scan_dt_build_strings(child, mem_start, mem_end); 2579 child = call_prom("peer", 1, 1, child); 2580 } 2581 } 2582 2583 static void __init scan_dt_build_struct(phandle node, unsigned long *mem_start, 2584 unsigned long *mem_end) 2585 { 2586 phandle child; 2587 char *namep, *prev_name, *sstart, *p, *ep, *lp, *path; 2588 unsigned long soff; 2589 unsigned char *valp; 2590 static char pname[MAX_PROPERTY_NAME] __prombss; 2591 int l, room, has_phandle = 0; 2592 2593 dt_push_token(OF_DT_BEGIN_NODE, mem_start, mem_end); 2594 2595 /* get the node's full name */ 2596 namep = (char *)*mem_start; 2597 room = *mem_end - *mem_start; 2598 if (room > 255) 2599 room = 255; 2600 l = call_prom("package-to-path", 3, 1, node, namep, room); 2601 if (l >= 0) { 2602 /* Didn't fit? Get more room. */ 2603 if (l >= room) { 2604 if (l >= *mem_end - *mem_start) 2605 namep = make_room(mem_start, mem_end, l+1, 1); 2606 call_prom("package-to-path", 3, 1, node, namep, l); 2607 } 2608 namep[l] = '\0'; 2609 2610 /* Fixup an Apple bug where they have bogus \0 chars in the 2611 * middle of the path in some properties, and extract 2612 * the unit name (everything after the last '/'). 2613 */ 2614 for (lp = p = namep, ep = namep + l; p < ep; p++) { 2615 if (*p == '/') 2616 lp = namep; 2617 else if (*p != 0) 2618 *lp++ = *p; 2619 } 2620 *lp = 0; 2621 *mem_start = ALIGN((unsigned long)lp + 1, 4); 2622 } 2623 2624 /* get it again for debugging */ 2625 path = prom_scratch; 2626 memset(path, 0, sizeof(prom_scratch)); 2627 call_prom("package-to-path", 3, 1, node, path, sizeof(prom_scratch) - 1); 2628 2629 /* get and store all properties */ 2630 prev_name = ""; 2631 sstart = (char *)dt_string_start; 2632 for (;;) { 2633 if (call_prom("nextprop", 3, 1, node, prev_name, 2634 pname) != 1) 2635 break; 2636 2637 /* skip "name" */ 2638 if (prom_strcmp(pname, "name") == 0) { 2639 prev_name = "name"; 2640 continue; 2641 } 2642 2643 /* find string offset */ 2644 soff = dt_find_string(pname); 2645 if (soff == 0) { 2646 prom_printf("WARNING: Can't find string index for" 2647 " <%s>, node %s\n", pname, path); 2648 break; 2649 } 2650 prev_name = sstart + soff; 2651 2652 /* get length */ 2653 l = call_prom("getproplen", 2, 1, node, pname); 2654 2655 /* sanity checks */ 2656 if (l == PROM_ERROR) 2657 continue; 2658 2659 /* push property head */ 2660 dt_push_token(OF_DT_PROP, mem_start, mem_end); 2661 dt_push_token(l, mem_start, mem_end); 2662 dt_push_token(soff, mem_start, mem_end); 2663 2664 /* push property content */ 2665 valp = make_room(mem_start, mem_end, l, 4); 2666 call_prom("getprop", 4, 1, node, pname, valp, l); 2667 *mem_start = ALIGN(*mem_start, 4); 2668 2669 if (!prom_strcmp(pname, "phandle")) 2670 has_phandle = 1; 2671 } 2672 2673 /* Add a "phandle" property if none already exist */ 2674 if (!has_phandle) { 2675 soff = dt_find_string("phandle"); 2676 if (soff == 0) 2677 prom_printf("WARNING: Can't find string index for <phandle> node %s\n", path); 2678 else { 2679 dt_push_token(OF_DT_PROP, mem_start, mem_end); 2680 dt_push_token(4, mem_start, mem_end); 2681 dt_push_token(soff, mem_start, mem_end); 2682 valp = make_room(mem_start, mem_end, 4, 4); 2683 *(__be32 *)valp = cpu_to_be32(node); 2684 } 2685 } 2686 2687 /* do all our children */ 2688 child = call_prom("child", 1, 1, node); 2689 while (child != 0) { 2690 scan_dt_build_struct(child, mem_start, mem_end); 2691 child = call_prom("peer", 1, 1, child); 2692 } 2693 2694 dt_push_token(OF_DT_END_NODE, mem_start, mem_end); 2695 } 2696 2697 static void __init flatten_device_tree(void) 2698 { 2699 phandle root; 2700 unsigned long mem_start, mem_end, room; 2701 struct boot_param_header *hdr; 2702 char *namep; 2703 u64 *rsvmap; 2704 2705 /* 2706 * Check how much room we have between alloc top & bottom (+/- a 2707 * few pages), crop to 1MB, as this is our "chunk" size 2708 */ 2709 room = alloc_top - alloc_bottom - 0x4000; 2710 if (room > DEVTREE_CHUNK_SIZE) 2711 room = DEVTREE_CHUNK_SIZE; 2712 prom_debug("starting device tree allocs at %lx\n", alloc_bottom); 2713 2714 /* Now try to claim that */ 2715 mem_start = (unsigned long)alloc_up(room, PAGE_SIZE); 2716 if (mem_start == 0) 2717 prom_panic("Can't allocate initial device-tree chunk\n"); 2718 mem_end = mem_start + room; 2719 2720 /* Get root of tree */ 2721 root = call_prom("peer", 1, 1, (phandle)0); 2722 if (root == (phandle)0) 2723 prom_panic ("couldn't get device tree root\n"); 2724 2725 /* Build header and make room for mem rsv map */ 2726 mem_start = ALIGN(mem_start, 4); 2727 hdr = make_room(&mem_start, &mem_end, 2728 sizeof(struct boot_param_header), 4); 2729 dt_header_start = (unsigned long)hdr; 2730 rsvmap = make_room(&mem_start, &mem_end, sizeof(mem_reserve_map), 8); 2731 2732 /* Start of strings */ 2733 mem_start = PAGE_ALIGN(mem_start); 2734 dt_string_start = mem_start; 2735 mem_start += 4; /* hole */ 2736 2737 /* Add "phandle" in there, we'll need it */ 2738 namep = make_room(&mem_start, &mem_end, 16, 1); 2739 prom_strscpy_pad(namep, "phandle", sizeof("phandle")); 2740 mem_start = (unsigned long)namep + prom_strlen(namep) + 1; 2741 2742 /* Build string array */ 2743 prom_printf("Building dt strings...\n"); 2744 scan_dt_build_strings(root, &mem_start, &mem_end); 2745 dt_string_end = mem_start; 2746 2747 /* Build structure */ 2748 mem_start = PAGE_ALIGN(mem_start); 2749 dt_struct_start = mem_start; 2750 prom_printf("Building dt structure...\n"); 2751 scan_dt_build_struct(root, &mem_start, &mem_end); 2752 dt_push_token(OF_DT_END, &mem_start, &mem_end); 2753 dt_struct_end = PAGE_ALIGN(mem_start); 2754 2755 /* Finish header */ 2756 hdr->boot_cpuid_phys = cpu_to_be32(prom.cpu); 2757 hdr->magic = cpu_to_be32(OF_DT_HEADER); 2758 hdr->totalsize = cpu_to_be32(dt_struct_end - dt_header_start); 2759 hdr->off_dt_struct = cpu_to_be32(dt_struct_start - dt_header_start); 2760 hdr->off_dt_strings = cpu_to_be32(dt_string_start - dt_header_start); 2761 hdr->dt_strings_size = cpu_to_be32(dt_string_end - dt_string_start); 2762 hdr->off_mem_rsvmap = cpu_to_be32(((unsigned long)rsvmap) - dt_header_start); 2763 hdr->version = cpu_to_be32(OF_DT_VERSION); 2764 /* Version 16 is not backward compatible */ 2765 hdr->last_comp_version = cpu_to_be32(0x10); 2766 2767 /* Copy the reserve map in */ 2768 memcpy(rsvmap, mem_reserve_map, sizeof(mem_reserve_map)); 2769 2770 #ifdef DEBUG_PROM 2771 { 2772 int i; 2773 prom_printf("reserved memory map:\n"); 2774 for (i = 0; i < mem_reserve_cnt; i++) 2775 prom_printf(" %llx - %llx\n", 2776 be64_to_cpu(mem_reserve_map[i].base), 2777 be64_to_cpu(mem_reserve_map[i].size)); 2778 } 2779 #endif 2780 /* Bump mem_reserve_cnt to cause further reservations to fail 2781 * since it's too late. 2782 */ 2783 mem_reserve_cnt = MEM_RESERVE_MAP_SIZE; 2784 2785 prom_printf("Device tree strings 0x%lx -> 0x%lx\n", 2786 dt_string_start, dt_string_end); 2787 prom_printf("Device tree struct 0x%lx -> 0x%lx\n", 2788 dt_struct_start, dt_struct_end); 2789 } 2790 2791 #ifdef CONFIG_PPC_MAPLE 2792 /* PIBS Version 1.05.0000 04/26/2005 has an incorrect /ht/isa/ranges property. 2793 * The values are bad, and it doesn't even have the right number of cells. */ 2794 static void __init fixup_device_tree_maple(void) 2795 { 2796 phandle isa; 2797 u32 rloc = 0x01002000; /* IO space; PCI device = 4 */ 2798 u32 isa_ranges[6]; 2799 char *name; 2800 2801 name = "/ht@0/isa@4"; 2802 isa = call_prom("finddevice", 1, 1, ADDR(name)); 2803 if (!PHANDLE_VALID(isa)) { 2804 name = "/ht@0/isa@6"; 2805 isa = call_prom("finddevice", 1, 1, ADDR(name)); 2806 rloc = 0x01003000; /* IO space; PCI device = 6 */ 2807 } 2808 if (!PHANDLE_VALID(isa)) 2809 return; 2810 2811 if (prom_getproplen(isa, "ranges") != 12) 2812 return; 2813 if (prom_getprop(isa, "ranges", isa_ranges, sizeof(isa_ranges)) 2814 == PROM_ERROR) 2815 return; 2816 2817 if (isa_ranges[0] != 0x1 || 2818 isa_ranges[1] != 0xf4000000 || 2819 isa_ranges[2] != 0x00010000) 2820 return; 2821 2822 prom_printf("Fixing up bogus ISA range on Maple/Apache...\n"); 2823 2824 isa_ranges[0] = 0x1; 2825 isa_ranges[1] = 0x0; 2826 isa_ranges[2] = rloc; 2827 isa_ranges[3] = 0x0; 2828 isa_ranges[4] = 0x0; 2829 isa_ranges[5] = 0x00010000; 2830 prom_setprop(isa, name, "ranges", 2831 isa_ranges, sizeof(isa_ranges)); 2832 } 2833 2834 #define CPC925_MC_START 0xf8000000 2835 #define CPC925_MC_LENGTH 0x1000000 2836 /* The values for memory-controller don't have right number of cells */ 2837 static void __init fixup_device_tree_maple_memory_controller(void) 2838 { 2839 phandle mc; 2840 u32 mc_reg[4]; 2841 char *name = "/hostbridge@f8000000"; 2842 u32 ac, sc; 2843 2844 mc = call_prom("finddevice", 1, 1, ADDR(name)); 2845 if (!PHANDLE_VALID(mc)) 2846 return; 2847 2848 if (prom_getproplen(mc, "reg") != 8) 2849 return; 2850 2851 prom_getprop(prom.root, "#address-cells", &ac, sizeof(ac)); 2852 prom_getprop(prom.root, "#size-cells", &sc, sizeof(sc)); 2853 if ((ac != 2) || (sc != 2)) 2854 return; 2855 2856 if (prom_getprop(mc, "reg", mc_reg, sizeof(mc_reg)) == PROM_ERROR) 2857 return; 2858 2859 if (mc_reg[0] != CPC925_MC_START || mc_reg[1] != CPC925_MC_LENGTH) 2860 return; 2861 2862 prom_printf("Fixing up bogus hostbridge on Maple...\n"); 2863 2864 mc_reg[0] = 0x0; 2865 mc_reg[1] = CPC925_MC_START; 2866 mc_reg[2] = 0x0; 2867 mc_reg[3] = CPC925_MC_LENGTH; 2868 prom_setprop(mc, name, "reg", mc_reg, sizeof(mc_reg)); 2869 } 2870 #else 2871 #define fixup_device_tree_maple() 2872 #define fixup_device_tree_maple_memory_controller() 2873 #endif 2874 2875 #ifdef CONFIG_PPC_CHRP 2876 /* 2877 * Pegasos and BriQ lacks the "ranges" property in the isa node 2878 * Pegasos needs decimal IRQ 14/15, not hexadecimal 2879 * Pegasos has the IDE configured in legacy mode, but advertised as native 2880 */ 2881 static void __init fixup_device_tree_chrp(void) 2882 { 2883 phandle ph; 2884 u32 prop[6]; 2885 u32 rloc = 0x01006000; /* IO space; PCI device = 12 */ 2886 char *name; 2887 int rc; 2888 2889 name = "/pci@80000000/isa@c"; 2890 ph = call_prom("finddevice", 1, 1, ADDR(name)); 2891 if (!PHANDLE_VALID(ph)) { 2892 name = "/pci@ff500000/isa@6"; 2893 ph = call_prom("finddevice", 1, 1, ADDR(name)); 2894 rloc = 0x01003000; /* IO space; PCI device = 6 */ 2895 } 2896 if (PHANDLE_VALID(ph)) { 2897 rc = prom_getproplen(ph, "ranges"); 2898 if (rc == 0 || rc == PROM_ERROR) { 2899 prom_printf("Fixing up missing ISA range on Pegasos...\n"); 2900 2901 prop[0] = 0x1; 2902 prop[1] = 0x0; 2903 prop[2] = rloc; 2904 prop[3] = 0x0; 2905 prop[4] = 0x0; 2906 prop[5] = 0x00010000; 2907 prom_setprop(ph, name, "ranges", prop, sizeof(prop)); 2908 } 2909 } 2910 2911 name = "/pci@80000000/ide@C,1"; 2912 ph = call_prom("finddevice", 1, 1, ADDR(name)); 2913 if (PHANDLE_VALID(ph)) { 2914 prom_printf("Fixing up IDE interrupt on Pegasos...\n"); 2915 prop[0] = 14; 2916 prop[1] = 0x0; 2917 prom_setprop(ph, name, "interrupts", prop, 2*sizeof(u32)); 2918 prom_printf("Fixing up IDE class-code on Pegasos...\n"); 2919 rc = prom_getprop(ph, "class-code", prop, sizeof(u32)); 2920 if (rc == sizeof(u32)) { 2921 prop[0] &= ~0x5; 2922 prom_setprop(ph, name, "class-code", prop, sizeof(u32)); 2923 } 2924 } 2925 } 2926 #else 2927 #define fixup_device_tree_chrp() 2928 #endif 2929 2930 #if defined(CONFIG_PPC64) && defined(CONFIG_PPC_PMAC) 2931 static void __init fixup_device_tree_pmac(void) 2932 { 2933 phandle u3, i2c, mpic; 2934 u32 u3_rev; 2935 u32 interrupts[2]; 2936 u32 parent; 2937 2938 /* Some G5s have a missing interrupt definition, fix it up here */ 2939 u3 = call_prom("finddevice", 1, 1, ADDR("/u3@0,f8000000")); 2940 if (!PHANDLE_VALID(u3)) 2941 return; 2942 i2c = call_prom("finddevice", 1, 1, ADDR("/u3@0,f8000000/i2c@f8001000")); 2943 if (!PHANDLE_VALID(i2c)) 2944 return; 2945 mpic = call_prom("finddevice", 1, 1, ADDR("/u3@0,f8000000/mpic@f8040000")); 2946 if (!PHANDLE_VALID(mpic)) 2947 return; 2948 2949 /* check if proper rev of u3 */ 2950 if (prom_getprop(u3, "device-rev", &u3_rev, sizeof(u3_rev)) 2951 == PROM_ERROR) 2952 return; 2953 if (u3_rev < 0x35 || u3_rev > 0x39) 2954 return; 2955 /* does it need fixup ? */ 2956 if (prom_getproplen(i2c, "interrupts") > 0) 2957 return; 2958 2959 prom_printf("fixing up bogus interrupts for u3 i2c...\n"); 2960 2961 /* interrupt on this revision of u3 is number 0 and level */ 2962 interrupts[0] = 0; 2963 interrupts[1] = 1; 2964 prom_setprop(i2c, "/u3@0,f8000000/i2c@f8001000", "interrupts", 2965 &interrupts, sizeof(interrupts)); 2966 parent = (u32)mpic; 2967 prom_setprop(i2c, "/u3@0,f8000000/i2c@f8001000", "interrupt-parent", 2968 &parent, sizeof(parent)); 2969 } 2970 #else 2971 #define fixup_device_tree_pmac() 2972 #endif 2973 2974 #ifdef CONFIG_PPC_EFIKA 2975 /* 2976 * The MPC5200 FEC driver requires an phy-handle property to tell it how 2977 * to talk to the phy. If the phy-handle property is missing, then this 2978 * function is called to add the appropriate nodes and link it to the 2979 * ethernet node. 2980 */ 2981 static void __init fixup_device_tree_efika_add_phy(void) 2982 { 2983 u32 node; 2984 char prop[64]; 2985 int rv; 2986 2987 /* Check if /builtin/ethernet exists - bail if it doesn't */ 2988 node = call_prom("finddevice", 1, 1, ADDR("/builtin/ethernet")); 2989 if (!PHANDLE_VALID(node)) 2990 return; 2991 2992 /* Check if the phy-handle property exists - bail if it does */ 2993 rv = prom_getprop(node, "phy-handle", prop, sizeof(prop)); 2994 if (rv <= 0) 2995 return; 2996 2997 /* 2998 * At this point the ethernet device doesn't have a phy described. 2999 * Now we need to add the missing phy node and linkage 3000 */ 3001 3002 /* Check for an MDIO bus node - if missing then create one */ 3003 node = call_prom("finddevice", 1, 1, ADDR("/builtin/mdio")); 3004 if (!PHANDLE_VALID(node)) { 3005 prom_printf("Adding Ethernet MDIO node\n"); 3006 call_prom("interpret", 1, 1, 3007 " s\" /builtin\" find-device" 3008 " new-device" 3009 " 1 encode-int s\" #address-cells\" property" 3010 " 0 encode-int s\" #size-cells\" property" 3011 " s\" mdio\" device-name" 3012 " s\" fsl,mpc5200b-mdio\" encode-string" 3013 " s\" compatible\" property" 3014 " 0xf0003000 0x400 reg" 3015 " 0x2 encode-int" 3016 " 0x5 encode-int encode+" 3017 " 0x3 encode-int encode+" 3018 " s\" interrupts\" property" 3019 " finish-device"); 3020 } 3021 3022 /* Check for a PHY device node - if missing then create one and 3023 * give it's phandle to the ethernet node */ 3024 node = call_prom("finddevice", 1, 1, 3025 ADDR("/builtin/mdio/ethernet-phy")); 3026 if (!PHANDLE_VALID(node)) { 3027 prom_printf("Adding Ethernet PHY node\n"); 3028 call_prom("interpret", 1, 1, 3029 " s\" /builtin/mdio\" find-device" 3030 " new-device" 3031 " s\" ethernet-phy\" device-name" 3032 " 0x10 encode-int s\" reg\" property" 3033 " my-self" 3034 " ihandle>phandle" 3035 " finish-device" 3036 " s\" /builtin/ethernet\" find-device" 3037 " encode-int" 3038 " s\" phy-handle\" property" 3039 " device-end"); 3040 } 3041 } 3042 3043 static void __init fixup_device_tree_efika(void) 3044 { 3045 int sound_irq[3] = { 2, 2, 0 }; 3046 int bcomm_irq[3*16] = { 3,0,0, 3,1,0, 3,2,0, 3,3,0, 3047 3,4,0, 3,5,0, 3,6,0, 3,7,0, 3048 3,8,0, 3,9,0, 3,10,0, 3,11,0, 3049 3,12,0, 3,13,0, 3,14,0, 3,15,0 }; 3050 u32 node; 3051 char prop[64]; 3052 int rv, len; 3053 3054 /* Check if we're really running on a EFIKA */ 3055 node = call_prom("finddevice", 1, 1, ADDR("/")); 3056 if (!PHANDLE_VALID(node)) 3057 return; 3058 3059 rv = prom_getprop(node, "model", prop, sizeof(prop)); 3060 if (rv == PROM_ERROR) 3061 return; 3062 if (prom_strcmp(prop, "EFIKA5K2")) 3063 return; 3064 3065 prom_printf("Applying EFIKA device tree fixups\n"); 3066 3067 /* Claiming to be 'chrp' is death */ 3068 node = call_prom("finddevice", 1, 1, ADDR("/")); 3069 rv = prom_getprop(node, "device_type", prop, sizeof(prop)); 3070 if (rv != PROM_ERROR && (prom_strcmp(prop, "chrp") == 0)) 3071 prom_setprop(node, "/", "device_type", "efika", sizeof("efika")); 3072 3073 /* CODEGEN,description is exposed in /proc/cpuinfo so 3074 fix that too */ 3075 rv = prom_getprop(node, "CODEGEN,description", prop, sizeof(prop)); 3076 if (rv != PROM_ERROR && (prom_strstr(prop, "CHRP"))) 3077 prom_setprop(node, "/", "CODEGEN,description", 3078 "Efika 5200B PowerPC System", 3079 sizeof("Efika 5200B PowerPC System")); 3080 3081 /* Fixup bestcomm interrupts property */ 3082 node = call_prom("finddevice", 1, 1, ADDR("/builtin/bestcomm")); 3083 if (PHANDLE_VALID(node)) { 3084 len = prom_getproplen(node, "interrupts"); 3085 if (len == 12) { 3086 prom_printf("Fixing bestcomm interrupts property\n"); 3087 prom_setprop(node, "/builtin/bestcom", "interrupts", 3088 bcomm_irq, sizeof(bcomm_irq)); 3089 } 3090 } 3091 3092 /* Fixup sound interrupts property */ 3093 node = call_prom("finddevice", 1, 1, ADDR("/builtin/sound")); 3094 if (PHANDLE_VALID(node)) { 3095 rv = prom_getprop(node, "interrupts", prop, sizeof(prop)); 3096 if (rv == PROM_ERROR) { 3097 prom_printf("Adding sound interrupts property\n"); 3098 prom_setprop(node, "/builtin/sound", "interrupts", 3099 sound_irq, sizeof(sound_irq)); 3100 } 3101 } 3102 3103 /* Make sure ethernet phy-handle property exists */ 3104 fixup_device_tree_efika_add_phy(); 3105 } 3106 #else 3107 #define fixup_device_tree_efika() 3108 #endif 3109 3110 #ifdef CONFIG_PPC_PASEMI_NEMO 3111 /* 3112 * CFE supplied on Nemo is broken in several ways, biggest 3113 * problem is that it reassigns ISA interrupts to unused mpic ints. 3114 * Add an interrupt-controller property for the io-bridge to use 3115 * and correct the ints so we can attach them to an irq_domain 3116 */ 3117 static void __init fixup_device_tree_pasemi(void) 3118 { 3119 u32 interrupts[2], parent, rval, val = 0; 3120 char *name, *pci_name; 3121 phandle iob, node; 3122 3123 /* Find the root pci node */ 3124 name = "/pxp@0,e0000000"; 3125 iob = call_prom("finddevice", 1, 1, ADDR(name)); 3126 if (!PHANDLE_VALID(iob)) 3127 return; 3128 3129 /* check if interrupt-controller node set yet */ 3130 if (prom_getproplen(iob, "interrupt-controller") !=PROM_ERROR) 3131 return; 3132 3133 prom_printf("adding interrupt-controller property for SB600...\n"); 3134 3135 prom_setprop(iob, name, "interrupt-controller", &val, 0); 3136 3137 pci_name = "/pxp@0,e0000000/pci@11"; 3138 node = call_prom("finddevice", 1, 1, ADDR(pci_name)); 3139 parent = ADDR(iob); 3140 3141 for( ; prom_next_node(&node); ) { 3142 /* scan each node for one with an interrupt */ 3143 if (!PHANDLE_VALID(node)) 3144 continue; 3145 3146 rval = prom_getproplen(node, "interrupts"); 3147 if (rval == 0 || rval == PROM_ERROR) 3148 continue; 3149 3150 prom_getprop(node, "interrupts", &interrupts, sizeof(interrupts)); 3151 if ((interrupts[0] < 212) || (interrupts[0] > 222)) 3152 continue; 3153 3154 /* found a node, update both interrupts and interrupt-parent */ 3155 if ((interrupts[0] >= 212) && (interrupts[0] <= 215)) 3156 interrupts[0] -= 203; 3157 if ((interrupts[0] >= 216) && (interrupts[0] <= 220)) 3158 interrupts[0] -= 213; 3159 if (interrupts[0] == 221) 3160 interrupts[0] = 14; 3161 if (interrupts[0] == 222) 3162 interrupts[0] = 8; 3163 3164 prom_setprop(node, pci_name, "interrupts", interrupts, 3165 sizeof(interrupts)); 3166 prom_setprop(node, pci_name, "interrupt-parent", &parent, 3167 sizeof(parent)); 3168 } 3169 3170 /* 3171 * The io-bridge has device_type set to 'io-bridge' change it to 'isa' 3172 * so that generic isa-bridge code can add the SB600 and its on-board 3173 * peripherals. 3174 */ 3175 name = "/pxp@0,e0000000/io-bridge@0"; 3176 iob = call_prom("finddevice", 1, 1, ADDR(name)); 3177 if (!PHANDLE_VALID(iob)) 3178 return; 3179 3180 /* device_type is already set, just change it. */ 3181 3182 prom_printf("Changing device_type of SB600 node...\n"); 3183 3184 prom_setprop(iob, name, "device_type", "isa", sizeof("isa")); 3185 } 3186 #else /* !CONFIG_PPC_PASEMI_NEMO */ 3187 static inline void fixup_device_tree_pasemi(void) { } 3188 #endif 3189 3190 static void __init fixup_device_tree(void) 3191 { 3192 fixup_device_tree_maple(); 3193 fixup_device_tree_maple_memory_controller(); 3194 fixup_device_tree_chrp(); 3195 fixup_device_tree_pmac(); 3196 fixup_device_tree_efika(); 3197 fixup_device_tree_pasemi(); 3198 } 3199 3200 static void __init prom_find_boot_cpu(void) 3201 { 3202 __be32 rval; 3203 ihandle prom_cpu; 3204 phandle cpu_pkg; 3205 3206 rval = 0; 3207 if (prom_getprop(prom.chosen, "cpu", &rval, sizeof(rval)) <= 0) 3208 return; 3209 prom_cpu = be32_to_cpu(rval); 3210 3211 cpu_pkg = call_prom("instance-to-package", 1, 1, prom_cpu); 3212 3213 if (!PHANDLE_VALID(cpu_pkg)) 3214 return; 3215 3216 prom_getprop(cpu_pkg, "reg", &rval, sizeof(rval)); 3217 prom.cpu = be32_to_cpu(rval); 3218 3219 prom_debug("Booting CPU hw index = %d\n", prom.cpu); 3220 } 3221 3222 static void __init prom_check_initrd(unsigned long r3, unsigned long r4) 3223 { 3224 #ifdef CONFIG_BLK_DEV_INITRD 3225 if (r3 && r4 && r4 != 0xdeadbeef) { 3226 __be64 val; 3227 3228 prom_initrd_start = is_kernel_addr(r3) ? __pa(r3) : r3; 3229 prom_initrd_end = prom_initrd_start + r4; 3230 3231 val = cpu_to_be64(prom_initrd_start); 3232 prom_setprop(prom.chosen, "/chosen", "linux,initrd-start", 3233 &val, sizeof(val)); 3234 val = cpu_to_be64(prom_initrd_end); 3235 prom_setprop(prom.chosen, "/chosen", "linux,initrd-end", 3236 &val, sizeof(val)); 3237 3238 reserve_mem(prom_initrd_start, 3239 prom_initrd_end - prom_initrd_start); 3240 3241 prom_debug("initrd_start=0x%lx\n", prom_initrd_start); 3242 prom_debug("initrd_end=0x%lx\n", prom_initrd_end); 3243 } 3244 #endif /* CONFIG_BLK_DEV_INITRD */ 3245 } 3246 3247 #ifdef CONFIG_PPC_SVM 3248 /* 3249 * Perform the Enter Secure Mode ultracall. 3250 */ 3251 static int __init enter_secure_mode(unsigned long kbase, unsigned long fdt) 3252 { 3253 register unsigned long r3 asm("r3") = UV_ESM; 3254 register unsigned long r4 asm("r4") = kbase; 3255 register unsigned long r5 asm("r5") = fdt; 3256 3257 asm volatile("sc 2" : "+r"(r3) : "r"(r4), "r"(r5)); 3258 3259 return r3; 3260 } 3261 3262 /* 3263 * Call the Ultravisor to transfer us to secure memory if we have an ESM blob. 3264 */ 3265 static void __init setup_secure_guest(unsigned long kbase, unsigned long fdt) 3266 { 3267 int ret; 3268 3269 if (!prom_svm_enable) 3270 return; 3271 3272 /* Switch to secure mode. */ 3273 prom_printf("Switching to secure mode.\n"); 3274 3275 /* 3276 * The ultravisor will do an integrity check of the kernel image but we 3277 * relocated it so the check will fail. Restore the original image by 3278 * relocating it back to the kernel virtual base address. 3279 */ 3280 relocate(KERNELBASE); 3281 3282 ret = enter_secure_mode(kbase, fdt); 3283 3284 /* Relocate the kernel again. */ 3285 relocate(kbase); 3286 3287 if (ret != U_SUCCESS) { 3288 prom_printf("Returned %d from switching to secure mode.\n", ret); 3289 prom_rtas_os_term("Switch to secure mode failed.\n"); 3290 } 3291 } 3292 #else 3293 static void __init setup_secure_guest(unsigned long kbase, unsigned long fdt) 3294 { 3295 } 3296 #endif /* CONFIG_PPC_SVM */ 3297 3298 /* 3299 * We enter here early on, when the Open Firmware prom is still 3300 * handling exceptions and the MMU hash table for us. 3301 */ 3302 3303 unsigned long __init prom_init(unsigned long r3, unsigned long r4, 3304 unsigned long pp, 3305 unsigned long r6, unsigned long r7, 3306 unsigned long kbase) 3307 { 3308 unsigned long hdr; 3309 3310 #ifdef CONFIG_PPC32 3311 unsigned long offset = reloc_offset(); 3312 reloc_got2(offset); 3313 #endif 3314 3315 /* 3316 * First zero the BSS 3317 */ 3318 memset(&__bss_start, 0, __bss_stop - __bss_start); 3319 3320 /* 3321 * Init interface to Open Firmware, get some node references, 3322 * like /chosen 3323 */ 3324 prom_init_client_services(pp); 3325 3326 /* 3327 * See if this OF is old enough that we need to do explicit maps 3328 * and other workarounds 3329 */ 3330 prom_find_mmu(); 3331 3332 /* 3333 * Init prom stdout device 3334 */ 3335 prom_init_stdout(); 3336 3337 prom_printf("Preparing to boot %s", linux_banner); 3338 3339 /* 3340 * Get default machine type. At this point, we do not differentiate 3341 * between pSeries SMP and pSeries LPAR 3342 */ 3343 of_platform = prom_find_machine_type(); 3344 prom_printf("Detected machine type: %x\n", of_platform); 3345 3346 #ifndef CONFIG_NONSTATIC_KERNEL 3347 /* Bail if this is a kdump kernel. */ 3348 if (PHYSICAL_START > 0) 3349 prom_panic("Error: You can't boot a kdump kernel from OF!\n"); 3350 #endif 3351 3352 /* 3353 * Check for an initrd 3354 */ 3355 prom_check_initrd(r3, r4); 3356 3357 /* 3358 * Do early parsing of command line 3359 */ 3360 early_cmdline_parse(); 3361 3362 #ifdef CONFIG_PPC_PSERIES 3363 /* 3364 * On pSeries, inform the firmware about our capabilities 3365 */ 3366 if (of_platform == PLATFORM_PSERIES || 3367 of_platform == PLATFORM_PSERIES_LPAR) 3368 prom_send_capabilities(); 3369 #endif 3370 3371 /* 3372 * Copy the CPU hold code 3373 */ 3374 if (of_platform != PLATFORM_POWERMAC) 3375 copy_and_flush(0, kbase, 0x100, 0); 3376 3377 /* 3378 * Initialize memory management within prom_init 3379 */ 3380 prom_init_mem(); 3381 3382 /* 3383 * Determine which cpu is actually running right _now_ 3384 */ 3385 prom_find_boot_cpu(); 3386 3387 /* 3388 * Initialize display devices 3389 */ 3390 prom_check_displays(); 3391 3392 #if defined(CONFIG_PPC64) && defined(__BIG_ENDIAN__) 3393 /* 3394 * Initialize IOMMU (TCE tables) on pSeries. Do that before anything else 3395 * that uses the allocator, we need to make sure we get the top of memory 3396 * available for us here... 3397 */ 3398 if (of_platform == PLATFORM_PSERIES) 3399 prom_initialize_tce_table(); 3400 #endif 3401 3402 /* 3403 * On non-powermacs, try to instantiate RTAS. PowerMacs don't 3404 * have a usable RTAS implementation. 3405 */ 3406 if (of_platform != PLATFORM_POWERMAC) 3407 prom_instantiate_rtas(); 3408 3409 #ifdef CONFIG_PPC64 3410 /* instantiate sml */ 3411 prom_instantiate_sml(); 3412 #endif 3413 3414 /* 3415 * On non-powermacs, put all CPUs in spin-loops. 3416 * 3417 * PowerMacs use a different mechanism to spin CPUs 3418 * 3419 * (This must be done after instanciating RTAS) 3420 */ 3421 if (of_platform != PLATFORM_POWERMAC) 3422 prom_hold_cpus(); 3423 3424 /* 3425 * Fill in some infos for use by the kernel later on 3426 */ 3427 if (prom_memory_limit) { 3428 __be64 val = cpu_to_be64(prom_memory_limit); 3429 prom_setprop(prom.chosen, "/chosen", "linux,memory-limit", 3430 &val, sizeof(val)); 3431 } 3432 #ifdef CONFIG_PPC64 3433 if (prom_iommu_off) 3434 prom_setprop(prom.chosen, "/chosen", "linux,iommu-off", 3435 NULL, 0); 3436 3437 if (prom_iommu_force_on) 3438 prom_setprop(prom.chosen, "/chosen", "linux,iommu-force-on", 3439 NULL, 0); 3440 3441 if (prom_tce_alloc_start) { 3442 prom_setprop(prom.chosen, "/chosen", "linux,tce-alloc-start", 3443 &prom_tce_alloc_start, 3444 sizeof(prom_tce_alloc_start)); 3445 prom_setprop(prom.chosen, "/chosen", "linux,tce-alloc-end", 3446 &prom_tce_alloc_end, 3447 sizeof(prom_tce_alloc_end)); 3448 } 3449 #endif 3450 3451 /* 3452 * Fixup any known bugs in the device-tree 3453 */ 3454 fixup_device_tree(); 3455 3456 /* 3457 * Now finally create the flattened device-tree 3458 */ 3459 prom_printf("copying OF device tree...\n"); 3460 flatten_device_tree(); 3461 3462 /* 3463 * in case stdin is USB and still active on IBM machines... 3464 * Unfortunately quiesce crashes on some powermacs if we have 3465 * closed stdin already (in particular the powerbook 101). 3466 */ 3467 if (of_platform != PLATFORM_POWERMAC) 3468 prom_close_stdin(); 3469 3470 /* 3471 * Call OF "quiesce" method to shut down pending DMA's from 3472 * devices etc... 3473 */ 3474 prom_printf("Quiescing Open Firmware ...\n"); 3475 call_prom("quiesce", 0, 0); 3476 3477 /* 3478 * And finally, call the kernel passing it the flattened device 3479 * tree and NULL as r5, thus triggering the new entry point which 3480 * is common to us and kexec 3481 */ 3482 hdr = dt_header_start; 3483 3484 prom_printf("Booting Linux via __start() @ 0x%lx ...\n", kbase); 3485 prom_debug("->dt_header_start=0x%lx\n", hdr); 3486 3487 #ifdef CONFIG_PPC32 3488 reloc_got2(-offset); 3489 #endif 3490 3491 /* Move to secure memory if we're supposed to be secure guests. */ 3492 setup_secure_guest(kbase, hdr); 3493 3494 __start(hdr, kbase, 0, 0, 0, 0, 0); 3495 3496 return 0; 3497 } 3498