1. 05 8月, 2011 1 次提交
    • A
      powerpc: Fix device tree claim code · 966728dd
      Anton Blanchard 提交于
      I have a box that fails in OF during boot with:
      
      DEFAULT CATCH!, exception-handler=fff00400
      at   %SRR0: 49424d2c4c6f6768   %SRR1: 800000004000b002
      
      ie "IBM,Logh". OF got corrupted with a device tree string.
      
      Looking at make_room and alloc_up, we claim the first chunk (1 MB)
      but we never claim any more. mem_end is always set to alloc_top
      which is the top of our available address space, guaranteeing we will
      never call alloc_up and claim more memory.
      
      Also alloc_up wasn't setting alloc_bottom to the bottom of the
      available address space.
      
      This doesn't help the box to boot, but we at least fail with
      an obvious error. We could relocate the device tree in a future
      patch.
      Signed-off-by: NAnton Blanchard <anton@samba.org>
      Cc: <stable@kernel.org>
      Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
      966728dd
  2. 04 5月, 2011 1 次提交
  3. 20 4月, 2011 1 次提交
  4. 31 7月, 2010 1 次提交
  5. 08 7月, 2010 1 次提交
  6. 28 4月, 2010 1 次提交
    • A
      powerpc/numa: Add form 1 NUMA affinity · 4b83c330
      Anton Blanchard 提交于
      Firmware changed the way it represents memory and cpu affinity on POWER7.
      Unfortunately the old method now caps the topology to work around issues
      with legacy operating systems. For Linux to get the correct topology we
      need to use the new form 1 affinity information.
      
      We set the form 1 field in the client architecture, and if we see "1" in the
      ibm,associativity-form property firmware supports form 1 affinity and
      we should look at the first field in the ibm,associativity-reference-points
      array. If not we use the second field as we always have.
      Signed-off-by: NAnton Blanchard <anton@samba.org>
      Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
      4b83c330
  7. 04 2月, 2010 1 次提交
  8. 03 2月, 2010 1 次提交
  9. 24 9月, 2009 1 次提交
    • A
      powerpc: Fix ibm,client-architecture-support printout · 049d0497
      Anton Blanchard 提交于
      On machines without the ibm,client-architecture-support call we were missing a
      newline. We may as well print the full name in all its glory too - its
      ibm,client-architecture-support, not ibm,client-architecture as I mistakenly
      wrote (a name only an IBM architect could love).
      
      For my penance I will write out ibm,client-architecture-support 100 times.
      
      Before:
      
      Calling ibm,client-architecture...command line: root=/dev/sda6 console=hvc0  quiet
      
      After:
      
      Calling ibm,client-architecture-support... not implemented
      command line: root=/dev/sda6 console=hvc0
      Signed-off-by: NAnton Blanchard <anton@samba.org>
      Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
      049d0497
  10. 20 8月, 2009 2 次提交
  11. 19 6月, 2009 1 次提交
  12. 17 6月, 2009 1 次提交
  13. 07 4月, 2009 3 次提交
  14. 24 3月, 2009 1 次提交
  15. 11 3月, 2009 1 次提交
  16. 08 1月, 2009 1 次提交
  17. 31 10月, 2008 1 次提交
  18. 21 10月, 2008 1 次提交
  19. 10 10月, 2008 1 次提交
    • P
      powerpc: Sync RPA note in zImage with kernel's RPA note · 91a00302
      Paul Mackerras 提交于
      Commit 9b09c6d9 ("powerpc: Change the
      default link address for pSeries zImage kernels") changed the
      real-base value in the CHRP note added by the addnote program from
      12MB to 32MB to give more space for Open Firmware to load the zImage.
      (The real-base value says where we want OF to position itself in
      memory.)  However, this change was ineffective on most pSeries
      machines, because the RPA note added by addnote has the "ignore me"
      flag set to 1.  This was intended to tell OF to ignore just the RPA
      note, but has the side effect of also making OF ignore the CHRP note
      (at least on most pSeries machines).
      
      To solve this we have to set the "ignore me" flag to 0 in the RPA
      note.  (We can't just omit the RPA note because that is equivalent to
      having an RPA note with default values, and the default values are not
      what we want.)  However, then we have to make sure the values in the
      zImage's RPA note match up with the values that the kernel supplies
      later in prom_init.c with either the ibm,client-architecture-support
      call or the process-elf-header call in prom_send_capabilities().
      
      So this sets the "ignore me" flag in the RPA note in addnote to 0, and
      adjusts the RPA note values in addnote.c and in prom_init.c to be
      consistent with each other and with the values in ibm_architecture_vec.
      
      However, since the wrapper is independent of the kernel, this doesn't
      ensure that the notes will stay consistent.  To ensure that, this adds
      code to addnote.c so that it can extract the kernel's RPA note from
      the kernel binary and put that in the zImage.  To that end, we put the
      kernel's fake ELF header (which contains the kernel's RPA note) into
      its own section, and arrange for wrapper to pull out that section with
      objcopy and pass it to addnote, which then extracts the RPA note from
      it and transfers it to the zImage.
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
      91a00302
  20. 16 9月, 2008 2 次提交
    • P
      powerpc: Make the 64-bit kernel as a position-independent executable · 549e8152
      Paul Mackerras 提交于
      This implements CONFIG_RELOCATABLE for 64-bit by making the kernel as
      a position-independent executable (PIE) when it is set.  This involves
      processing the dynamic relocations in the image in the early stages of
      booting, even if the kernel is being run at the address it is linked at,
      since the linker does not necessarily fill in words in the image for
      which there are dynamic relocations.  (In fact the linker does fill in
      such words for 64-bit executables, though not for 32-bit executables,
      so in principle we could avoid calling relocate() entirely when we're
      running a 64-bit kernel at the linked address.)
      
      The dynamic relocations are processed by a new function relocate(addr),
      where the addr parameter is the virtual address where the image will be
      run.  In fact we call it twice; once before calling prom_init, and again
      when starting the main kernel.  This means that reloc_offset() returns
      0 in prom_init (since it has been relocated to the address it is running
      at), which necessitated a few adjustments.
      
      This also changes __va and __pa to use an equivalent definition that is
      simpler.  With the relocatable kernel, PAGE_OFFSET and MEMORY_START are
      constants (for 64-bit) whereas PHYSICAL_START is a variable (and
      KERNELBASE ideally should be too, but isn't yet).
      
      With this, relocatable kernels still copy themselves down to physical
      address 0 and run there.
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      549e8152
    • P
      powerpc: Make it possible to move the interrupt handlers away from the kernel · 1f6a93e4
      Paul Mackerras 提交于
      This changes the way that the exception prologs transfer control to
      the handlers in 64-bit kernels with the aim of making it possible to
      have the prologs separate from the main body of the kernel.  Now,
      instead of computing the address of the handler by taking the top
      32 bits of the paca address (to get the 0xc0000000........ part) and
      ORing in something in the bottom 16 bits, we get the base address of
      the kernel by doing a load from the paca and add an offset.
      
      This also replaces an mfmsr and an ori to compute the MSR value for
      the handler with a load from the paca.  That makes it unnecessary to
      have a separate version of EXCEPTION_PROLOG_PSERIES that forces 64-bit
      mode.
      
      We can no longer use a direct branches in the exception prolog code,
      which means that the SLB miss handlers can't branch directly to
      .slb_miss_realmode any more.  Instead we have to compute the address
      and do an indirect branch.  This is conditional on CONFIG_RELOCATABLE;
      for non-relocatable kernels we use a direct branch as before.  (A later
      change will allow CONFIG_RELOCATABLE to be set on 64-bit powerpc.)
      
      Since the secondary CPUs on pSeries start execution in the first 0x100
      bytes of real memory and then have to get to wherever the kernel is,
      we can't use a direct branch to get there.  Instead this changes
      __secondary_hold_spinloop from a flag to a function pointer.  When it
      is set to a non-NULL value, the secondary CPUs jump to the function
      pointed to by that value.
      
      Finally this eliminates one code difference between 32-bit and 64-bit
      by making __secondary_hold be the text address of the secondary CPU
      spinloop rather than a function descriptor for it.
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      1f6a93e4
  21. 28 7月, 2008 1 次提交
  22. 25 7月, 2008 1 次提交
  23. 01 7月, 2008 1 次提交
  24. 30 6月, 2008 1 次提交
  25. 17 4月, 2008 1 次提交
    • D
      [POWERPC] Efika: Really, don't pretend to be CHRP · 7f4392cd
      David Woodhouse 提交于
      Fedora 9 works on Efika without the separate 'device-tree supplement',
      thanks to the kernel's own fixups. With one exception -- because 'CHRP'
      still appears on the 'machine:' line in /proc/cpuinfo, the installer
      misdetects the platform and misconfigures yaboot, putting it into a PReP
      boot partition instead of in the /boot filesystem where the Efika's
      firmware could find it.
      
      The kernel's fixups for Efika already correct one instance of 'chrp', in
      the 'device_type' property. This fixes it in the 'CODEGEN,description'
      property too, since that's what's exposed to userspace in /proc/cpuinfo.
      Signed-off-by: NDavid Woodhouse <dwmw2@infradead.org>
      Acked-by: NGrant Likely <grant.likely@secretlab.ca>
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      7f4392cd
  26. 27 1月, 2008 1 次提交
    • G
      [POWERPC] Efika: prune fixups and make them more carefull · 94d2dde7
      Grant Likely 提交于
      Prune back Efika fixups to only include changes that are actually required
      to get a working system.  Most of the drivers can accept the compatible
      properties, even if they don't match the what is recommented in the generic
      names recommended practice document.
      
      This patch also adds extra checks so that fixups are not performed blindly.
      Instead, the code first verifies that the device tree is faulty before
      making any changes.  This way, if the Efika firmware is updated to fix
      these issues, then the fixups will no longer get applied.
      
      At this point; here is the list of fixups needed for the efika:
      1. If the device_type property on the root node is 'chrp', then Linux won't
         boot.  Change device_type to 'efika' to avoid this condition
      2. Add full interrupt list to the bestcomm node.  In actual fact, the
         bestcomm interrupts property is technically correct, it just doesn't
         expose the same granularity as the device driver expects.  All other
         5200 device trees provide a separate irq number for each bestcomm
         channel.  Rather than hack the driver, it's simpler to fix it up
      3. /builtin/sound node is missing an interrupts property
      4. /builtin/ethernet node is missing a phy-handle property and the
         device driver doesn't know what to do without one.
      Signed-off-by: NGrant Likely <grant.likely@secretlab.ca>
      94d2dde7
  27. 10 1月, 2008 1 次提交
  28. 08 11月, 2007 1 次提交
  29. 13 9月, 2007 1 次提交
  30. 22 8月, 2007 1 次提交
    • O
      [POWERPC] Advertise correct IDE mode on Pegasos2 · 556ecf9b
      Olaf Hering 提交于
      The built-in IDE controller is configured in legacy mode, but the PCI
      registers advertise native mode.  Force the PCI class into legacy
      mode. This allows pata_via to access two drives.
      
      The Pegasos specific irq enforcement in the via82cxxx driver must stay
      because there is apparently no generic way to setup irq per channel.
      
      Tested on Pegasos2 with firmware version 20040810, and two IDE disks.
      Signed-off-by: NOlaf Hering <olaf@aepfle.de>
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      556ecf9b
  31. 14 6月, 2007 1 次提交
    • J
      [POWERPC] Donate idle CPU cycles on dedicated partitions · d8c391a5
      Jake Moilanen 提交于
      A Power6 can give up CPU cycles on a dedicated CPU (as opposed to a
      shared CPU) to other shared processors if the administrator asks for it
      (via the HMC).
      
      This enables that to work properly on P6.
      
      This just involves setting a bit in the CAS structure as well as the
      VPA.  To donate cycles, a CPU has to have all SMT threads idle and
      have the donate bit set in the VPA.  Then call H_CEDE.
      
      The reason why shared processors just aren't used is because dedicated
      CPUs are guaranteed an actual processor, yet the system is still able to
      increase the capacity of the shared CPU pool.
      
      Also rename the VPA's cpuctls_task_attrs field to a more accurate name.
      Signed-off-by: NJake Moilanen <moilanen@austin.ibm.com>
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      d8c391a5
  32. 08 5月, 2007 2 次提交
  33. 07 5月, 2007 1 次提交
  34. 13 4月, 2007 1 次提交
  35. 13 2月, 2007 1 次提交