1. 19 Jan, 2015 6 commits
    • Thomas Petazzoni's avatar
      bus: mvebu-mbus: make sure SDRAM CS for DMA don't overlap the MBus bridge window · 1737cac6
      Thomas Petazzoni authored
      The mvebu-mbus driver reads the SDRAM window registers, and make the
      information about the DRAM CS configuration available to device
      drivers using the mv_mbus_dram_info() API. This information is used by
      the DMA-capable device drivers to program their address decoding
      windows.
      
      Until now, we were basically providing the SDRAM window register
      details as is. However, it turns out that the DMA capability of the
      CESA cryptographic engine consists in doing DMA being the DRAM and the
      crypto SRAM mapped as a MBus window. For this case, it is very
      important that the SDRAM CS information does not overlap with the MBus
      bridge window.
      
      Therefore, this commit improves the mvebu-mbus driver to make sure we
      adjust the SDRAM CS information so that it doesn't overlap with the
      MBus bridge window. This problem was reported by Boris Brezillon,
      while working on the mv_cesa driver for Armada 37x/38x/XP. We use the
      memblock memory information to know where the usable RAM is located,
      as this information is guaranteed to be correct on all SoC variants.
      
      We could have used the MBus bridge window registers on Armada 370/XP,
      but they are not really used on Armada 375/38x (Cortex-A9 based),
      since the PL310 L2 filtering is used instead to discriminate between
      RAM accesses and I/O accesses. Therefore, using the memblock
      information is more generic and works accross the different platforms.
      Reported-by: default avatarBoris Brezillon <boris.brezillon@free-electrons.com>
      Signed-off-by: default avatarThomas Petazzoni <thomas.petazzoni@free-electrons.com>
      [Andrew Lunn <andrew@lunn.ch>: Fixed merge conflict]
      Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
      1737cac6
    • Michal Mazur's avatar
      bus: mvebu-mbus: fix support of MBus window 13 on Armada XP/375/38x · 7fdf3d8a
      Michal Mazur authored
      On Armada XP, 375 and 38x the MBus window 13 has the remap capability,
      like windows 0 to 7. However, the mvebu-mbus driver isn't currently
      taking into account this special case, which means that when window 13
      is actually used, the remap registers are left to 0, making the device
      using this MBus window unavailable.
      
      To make things even more fun, the hardware designers have chosen to
      put the window 13 remap registers in a completely custom location,
      using a logic that differs from the one used for all other remappable
      windows.
      
      To solve this problem, this commit:
      
       * Adds a SoC specific function to calculate offset of remap registers
         to the mvebu_mbus_soc_data structure. This function,
         ->win_remap_offset(), returns the offset of the remap registers, or
         MVEBU_MBUS_NO_REMAP if the window does not have the remap
         capability. This new function replaces the previous integer field
         num_remappable_wins, which was insufficient to encode the special
         case of window 13.
      
       * Adds an implementation of the ->win_remap_offset() function for the
         various SoC families. Some have 2 first windows that are remapable,
         some the 4 first, some the 8 first, and then the Armada XP/375/38x
         case where the 8 first are remapable plus the special window
         13. This is implemented in functions
         generic_mbus_win_remap_2_offset(),
         generic_mbus_win_remap_4_offset(),
         generic_mbus_win_remap_8_offset() and
         armada_xp_mbus_win_remap_offset() respectively.
      
       * Change the code to use the ->win_remap_offset() function when
         accessing the remap registers, and also to use a newly introduced
         mvebu_mbus_window_is_remappable() helper function that tells
         whether a given window is remapable or not.
      
       * Separate Armada 370 from XP/375/38X because the window 13 of Armada
         370 does not support the remap capability.
      
      [Thomas: adapted for the mainline kernel, minor clarifications in the
      code, reword the commit log.]
      Signed-off-by: default avatarMichal Mazur <arg@semihalf.com>
      Signed-off-by: default avatarThomas Petazzoni <thomas.petazzoni@free-electrons.com>
      [Andrew Lunn <andrew@lunn.ch>: Undo the simple fix for stable]
      Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
      7fdf3d8a
    • Thomas Petazzoni's avatar
      ARM: mvebu: use arm_coherent_dma_ops and re-enable hardware I/O coherency · 1bd4d8a6
      Thomas Petazzoni authored
      Now that we have enabled automatic I/O synchronization barriers, we no
      longer need any explicit barriers. We can therefore simplify
      arch/arm/mach-mvebu/coherency.c by using the existing
      arm_coherent_dma_ops instead of our custom mvebu_hwcc_dma_ops, and
      re-enable hardware I/O coherency support.
      Signed-off-by: default avatarThomas Petazzoni <thomas.petazzoni@free-electrons.com>
      [Andrew Lunn <andrew@lunn.ch>: Remove forgotten comment]
      Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
      1bd4d8a6
    • Thomas Petazzoni's avatar
      bus: mvebu-mbus: use automatic I/O synchronization barriers · a0b5cd4a
      Thomas Petazzoni authored
      Instead of using explicit I/O synchronization barriers shoehorned
      inside the streaming DMA mappings API (in
      arch/arm/mach-mvebu/coherency.c), we are switching to use automatic
      I/O synchronization barrier.
      
      The primary motivation for this change is that explicit I/O
      synchronization barriers are not only needed for streaming DMA
      mappings (which can easily be done by overriding the dma_map_ops), but
      also for coherent DMA mappings (which is a lot less easy to do, since
      the kernel assumes such mappings are coherent and don't require any
      sort of cache maintenance operation to ensure the consistency of the
      buffers).
      
      Switching to automatic I/O synchronization barriers will also allow us
      to use the existing arm_coherent_dma_ops instead of our custom
      arm_dma_ops.
      
      In order to use automatic I/O synchronization barriers, this commit
      changes mvebu-mbus in two ways:
      
       - It enables automatic I/O synchronization barriers in the 0x84
         register of the MBus bridge, by enabling such barriers for all MBus
         units. This enables automatic barriers for the on-SoC peripherals
         that are doing DMA.
      
       - It enables the SyncEnable bit in the MBus windows, so that PCIe
         devices also use automatic I/O synchronization barrier.
      
      This automatic synchronization barrier relies on the assumption that
      at least one register of a given hardware unit is read before the
      driver accesses the DMA mappings modified by this unit. This
      assumption is guaranteed for PCI devices by vertue of the PCI
      standard, and we can reasonably verify that this assumption is also
      true for the limited number of platform drivers doing DMA used on
      Marvell EBU platforms.
      Signed-off-by: default avatarThomas Petazzoni <thomas.petazzoni@free-electrons.com>
      Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
      a0b5cd4a
    • Andrew Lunn's avatar
      Merge branch 'mvebu/fixes-3' into mvebu/soc · fe6e91e3
      Andrew Lunn authored
      fe6e91e3
    • Andrew Lunn's avatar
      bus: mvebu-mbus: fix support of MBus window 13 · 38bdf45f
      Andrew Lunn authored
      On Armada XP, 375 and 38x the MBus window 13 has the remap capability,
      like windows 0 to 7. However, the mvebu-mbus driver isn't currently
      taking into account this special case, which means that when window 13
      is actually used, the remap registers are left to 0, making the device
      using this MBus window unavailable.
      
      As a minimal fix for stable, don't use window 13. A full fix will
      follow later.
      
      Fixes: fddddb52 ("bus: introduce an Marvell EBU MBus driver")
      Cc: <stable@vger.kernel.org> # v3.10+
      Reviewed-by: default avatarThomas Petazzoni <thomas.petazzoni@free-electrons.com>
      Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
      38bdf45f
  2. 17 Jan, 2015 1 commit
  3. 11 Jan, 2015 9 commits
  4. 10 Jan, 2015 10 commits
    • Linus Torvalds's avatar
      Merge tag 'vfio-v3.19-rc4' of git://github.com/awilliam/linux-vfio · 4850d37d
      Linus Torvalds authored
      Pull VFIO fix from Alex Williamson:
       "Fix PCI header check in vfio_pci_probe() (Wei Yang)"
      
      * tag 'vfio-v3.19-rc4' of git://github.com/awilliam/linux-vfio:
        vfio-pci: Fix the check on pci device type in vfio_pci_probe()
      4850d37d
    • Linus Torvalds's avatar
      Merge tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi · aff8ad59
      Linus Torvalds authored
      Pull SCSI fix from James Bottomley:
       "Just one fix: a qlogic busy wait regression"
      
      * tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi:
        qla2xxx: fix busy wait regression
      aff8ad59
    • Linus Torvalds's avatar
      Merge tag 'sound-3.19-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound · eb749269
      Linus Torvalds authored
      Pull sound fixes from Takashi Iwai:
       "All a few small regression or stable fixes: a Nvidia HDMI ID addition,
        a regression fix for CAIAQ stream count, a typo fix for GPIO setup
        with STAC/IDT HD-audio codecs, and a Fireworks big-endian fix"
      
      * tag 'sound-3.19-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound:
        ALSA: fireworks: fix an endianness bug for transaction length
        ALSA: hda - Add new GPU codec ID 0x10de0072 to snd-hda
        ALSA: hda - Fix wrong gpio_dir & gpio_mask hint setups for IDT/STAC codecs
        ALSA: snd-usb-caiaq: fix stream count check
      eb749269
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid · 28023d2a
      Linus Torvalds authored
      Pull HID updates from Jiri Kosina:
      
       - bounds checking fixes in logitech and roccat drivers, from Peter Wu
         and Dan Carpenter
      
       - double-kfree fix in i2c-hid driver on bus shutdown, from Mika
         Westerberg
      
       - a couple of various small driver fixes
      
       - a few device id additions
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid:
        HID: roccat: potential out of bounds in pyra_sysfs_write_settings()
        HID: Add a new id 0x501a for Genius MousePen i608X
        HID: logitech-hidpp: prefix the name with "Logitech"
        HID: logitech-hidpp: avoid unintended fall-through
        HID: Allow HID_BATTERY_STRENGTH to be enabled
        HID: i2c-hid: Do not free buffers in i2c_hid_stop()
        HID: add battery quirk for USB_DEVICE_ID_APPLE_ALU_WIRELESS_2011_ISO keyboard
        HID: logitech-hidpp: check WTP report length
        HID: logitech-dj: check report length
      28023d2a
    • Linus Torvalds's avatar
      Merge branch 'drm-fixes' of git://people.freedesktop.org/~airlied/linux · 1dd34daa
      Linus Torvalds authored
      Pull drm fixes from Dave Airlie:
       "I'm briefly working between holidays and LCA, so this is close to a
        couple of weeks of fixes,
      
        Two sets of amdkfd fixes, this is a new feature this kernel, and this
        pull fixes a few issues since it got merged, ordering when built-in to
        kernel and also the iommu vs gpu ordering patch, it also reworks the
        ioctl before the initial release.
      
        Otherwise:
         - radeon: some misc fixes all over, hdmi, 4k, dpm
         - nouveau: mcp77 init fixes, oops fix, bug on fix, msi fix
         - i915: power fixes, revert VGACNTR patch
      
        Probably be quiteer next week since I'll be at LCA anyways"
      
      * 'drm-fixes' of git://people.freedesktop.org/~airlied/linux: (33 commits)
        drm/amdkfd: rewrite kfd_ioctl() according to drm_ioctl()
        drm/amdkfd: reformat IOCTL definitions to drm-style
        drm/amdkfd: Do copy_to/from_user in general kfd_ioctl()
        drm/radeon: integer underflow in radeon_cp_dispatch_texture()
        drm/radeon: adjust default bapm settings for KV
        drm/radeon: properly filter DP1.2 4k modes on non-DP1.2 hw
        drm/radeon: fix sad_count check for dce3
        drm/radeon: KV has three PPLLs (v2)
        drm/amdkfd: unmap VMID<-->PASID when relesing VMID (non-HWS)
        drm/radeon: Init amdkfd only if it was compiled
        amdkfd: actually allocate longs for the pasid bitmask
        drm/nouveau/nouveau: Do not BUG_ON(!spin_is_locked()) on UP
        drm/nv4c/mc: disable msi
        drm/nouveau/fb/ram/mcp77: enable NISO poller
        drm/nouveau/fb/ram/mcp77: use carveout reg to determine size
        drm/nouveau/fb/ram/mcp77: subclass nouveau_ram
        drm/nouveau: wake up the card if necessary during gem callbacks
        drm/nouveau/device: Add support for GK208B, resolves bug 86935
        drm/nouveau: fix missing return statement in nouveau_ttm_tt_unpopulate
        drm/nouveau/bios: fix oops on pre-nv50 chipsets
        ...
      1dd34daa
    • Linus Torvalds's avatar
      Merge tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux · d80b34c9
      Linus Torvalds authored
      Pull arm64 fixes from Will Deacon:
       "Here is a handful of minor arm64 fixes discovered and fixed over the
        Christmas break.  The main part is adding some missing #includes that
        we seem to be getting transitively but have started causing problems
        in -next.
      
         - Fix early mapping fixmap corruption by EFI runtime services
         - Fix __NR_compat_syscalls off-by-one
         - Add missing sanity checks for some 32-bit registers
         - Add some missing #includes which we get transitively
         - Remove unused prepare_to_copy() macro"
      
      * tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux:
        arm64/efi: add missing call to early_ioremap_reset()
        arm64: fix missing asm/io.h include in kernel/smp_spin_table.c
        arm64: fix missing asm/alternative.h include in kernel/module.c
        arm64: fix missing linux/bug.h include in asm/arch_timer.h
        arm64: fix missing asm/pgtable-hwdef.h include in asm/processor.h
        arm64: sanity checks: add missing AArch32 registers
        arm64: Remove unused prepare_to_copy()
        arm64: Correct __NR_compat_syscalls for bpf
      d80b34c9
    • Linus Torvalds's avatar
      Merge tag 'for_linus-3.19-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/jwessel/kgdb · aa929135
      Linus Torvalds authored
      Pull kgdb/kdb fixes from Jason Wessel:
       "These have been around since 3.17 and in kgdb-next for the last 9
        weeks and some will go back to -stable.
      
        Summary of changes:
      
        Cleanups
         - kdb: Remove unused command flags, repeat flags and KDB_REPEAT_NONE
      
        Fixes
         - kgdb/kdb: Allow access on a single core, if a CPU round up is
           deemed impossible, which will allow inspection of the now "trashed"
           kernel
         - kdb: Add enable mask for the command groups
         - kdb: access controls to restrict sensitive commands"
      
      * tag 'for_linus-3.19-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/jwessel/kgdb:
        kernel/debug/debug_core.c: Logging clean-up
        kgdb: timeout if secondary CPUs ignore the roundup
        kdb: Allow access to sensitive commands to be restricted by default
        kdb: Add enable mask for groups of commands
        kdb: Categorize kdb commands (similar to SysRq categorization)
        kdb: Remove KDB_REPEAT_NONE flag
        kdb: Use KDB_REPEAT_* values as flags
        kdb: Rename kdb_register_repeat() to kdb_register_flags()
        kdb: Rename kdb_repeat_t to kdb_cmdflags_t, cmd_repeat to cmd_flags
        kdb: Remove currently unused kdbtab_t->cmd_flags
      aa929135
    • Linus Torvalds's avatar
      Merge branch 'for-3.19' of git://linux-nfs.org/~bfields/linux · dc9319f5
      Linus Torvalds authored
      Pull two nfsd bugfixes from Bruce Fields.
      
      * 'for-3.19' of git://linux-nfs.org/~bfields/linux:
        rpc: fix xdr_truncate_encode to handle buffer ending on page boundary
        nfsd: fix fi_delegees leak when fi_had_conflict returns true
      dc9319f5
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/sage/ceph-client · 20ebb345
      Linus Torvalds authored
      Pull two Ceph fixes from Sage Weil:
       "These are both pretty trivial: a sparse warning fix and size_t printk
        thing"
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/sage/ceph-client:
        libceph: fix sparse endianness warnings
        ceph: use %zu for len in ceph_fill_inline_data()
      20ebb345
    • Linus Torvalds's avatar
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/linux-btrfs · 03c751a5
      Linus Torvalds authored
      Pull btrfs fixes from Chris Mason:
       "None of these are huge, but my commit does fix a regression from 3.18
        that could cause lost files during log replay.
      
        This also adds Dave Sterba to the list of Btrfs maintainers.  It
        doesn't mean we're doing things differently, but Dave has really been
        helping with the maintainer workload for years"
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/linux-btrfs:
        Btrfs: don't delay inode ref updates during log replay
        Btrfs: correctly get tree level in tree_backref_for_extent
        Btrfs: call inode_dec_link_count() on mkdir error path
        Btrfs: abort transaction if we don't find the block group
        Btrfs, scrub: uninitialized variable in scrub_extent_for_parity()
        Btrfs: add more maintainers
      03c751a5
  5. 09 Jan, 2015 14 commits