1. 20 8月, 2009 1 次提交
  2. 19 6月, 2009 1 次提交
  3. 17 6月, 2009 1 次提交
  4. 07 4月, 2009 3 次提交
  5. 24 3月, 2009 1 次提交
  6. 11 3月, 2009 1 次提交
  7. 08 1月, 2009 1 次提交
  8. 31 10月, 2008 1 次提交
  9. 21 10月, 2008 1 次提交
  10. 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
  11. 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
  12. 28 7月, 2008 1 次提交
  13. 25 7月, 2008 1 次提交
  14. 01 7月, 2008 1 次提交
  15. 30 6月, 2008 1 次提交
  16. 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
  17. 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
  18. 10 1月, 2008 1 次提交
  19. 08 11月, 2007 1 次提交
  20. 13 9月, 2007 1 次提交
  21. 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
  22. 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
  23. 08 5月, 2007 2 次提交
  24. 07 5月, 2007 1 次提交
  25. 13 4月, 2007 1 次提交
  26. 13 2月, 2007 1 次提交
  27. 11 12月, 2006 1 次提交
    • P
      [POWERPC] Support ibm,dynamic-reconfiguration-memory nodes · 0204568a
      Paul Mackerras 提交于
      For PAPR partitions with large amounts of memory, the firmware has an
      alternative, more compact representation for the information about the
      memory in the partition and its NUMA associativity information.  This
      adds the code to the kernel to parse this alternative representation.
      
      The other part of this patch is telling the firmware that we can
      handle the alternative representation.  There is however a subtlety
      here, because the firmware will invoke a reboot if the memory
      representation we request is different from the representation that
      firmware is currently using.  This is because firmware can't change
      the representation on the fly.  Further, some firmware versions used
      on POWER5+ machines have a bug where this reboot leaves the machine
      with an altered value of load-base, which will prevent any kernel
      booting until it is reset to the normal value (0x4000).  Because of
      this bug, we do NOT set fake_elf.rpanote.new_mem_def = 1, and thus we
      do not request the new representation on POWER5+ and earlier machines.
      We do request the new representation on POWER6, which uses the
      ibm,client-architecture-support call.
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      0204568a
  28. 04 12月, 2006 3 次提交
    • P
      [POWERPC] Tell firmware we can handle POWER6 compatible mode · 0efbc18a
      Paul Mackerras 提交于
      This adds the "logical" PVR value used by POWER6 in "compatible" mode
      to the list of PVR values that the kernel tells firmware it is able to
      handle.
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      0efbc18a
    • P
      [POWERPC] Distinguish POWER6 partition modes and tell userspace · 974a76f5
      Paul Mackerras 提交于
      This adds code to look at the properties firmware puts in the device
      tree to determine what compatibility mode the partition is in on
      POWER6 machines, and set the ELF aux vector AT_HWCAP and AT_PLATFORM
      entries appropriately.
      
      Specifically, we look at the cpu-version property in the cpu node(s).
      If that contains a "logical" PVR value (of the form 0x0f00000x), we
      call identify_cpu again with this PVR value.  A value of 0x0f000001
      indicates the partition is in POWER5+ compatibility mode, and a value
      of 0x0f000002 indicates "POWER6 architected" mode, with various
      extensions disabled.  We also look for various other properties:
      ibm,dfp, ibm,purr and ibm,spurr.
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      974a76f5
    • J
      [POWERPC] Cell iommu support · 165785e5
      Jeremy Kerr 提交于
      This patch adds full cell iommu support (and iommu disabled mode).
      
      It implements mapping/unmapping of iommu pages on demand using the
      standard powerpc iommu framework.  It also supports running with
      iommu disabled for machines with less than 2GB of memory.  (The
      default is off in that case, though it can be forced on with the
      kernel command line option iommu=force).
      Signed-off-by: NJeremy Kerr <jk@ozlabs.org>
      Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
      Signed-off-by: NPaul Mackerras <paulus@samba.org>
      165785e5
  29. 30 8月, 2006 1 次提交
  30. 25 7月, 2006 2 次提交
  31. 07 7月, 2006 3 次提交