1. 03 5月, 2017 4 次提交
    • V
      ARCv2: mm: micro-optimize region flush generated code · f734a310
      Vineet Gupta 提交于
      DC_CTRL.RGN_OP is 3 bits wide, however only 1 bit is used in current
      programming model (0: flush, 1: invalidate)
      
      The current code targetting 3 bits leads to additional 8 byte AND
      operation which can be elided given that only 1 bit is ever set by
      software and/or looked at by hardware
      
      before
      ------
      
      | 80b63324 <__dma_cache_wback_inv_l1>:
      | 80b63324:	clri	r3
      | 80b63328:	lr	r2,[dc_ctrl]
      | 80b6332c:	and	r2,r2,0xfffff1ff	<--- 8 bytes insn
      | 80b63334:	or	r2,r2,576
      | 80b63338:	sr	r2,[dc_ctrl]
      | ...
      | ...
      | 80b63360 <__dma_cache_inv_l1>:
      | 80b63360:	clri	r3
      | 80b63364:	lr	r2,[dc_ctrl]
      | 80b63368:	and	r2,r2,0xfffff1ff	<--- 8 bytes insn
      | 80b63370:	bset_s	r2,r2,0x9
      | 80b63372:	sr	r2,[dc_ctrl]
      | ...
      | ...
      | 80b6338c <__dma_cache_wback_l1>:
      | 80b6338c:	clri	r3
      | 80b63390:	lr	r2,[dc_ctrl]
      | 80b63394:	and	r2,r2,0xfffff1ff	<--- 8 bytes insn
      | 80b6339c:	sr	r2,[dc_ctrl]
      
      after (AND elided totally in 2 cases, replaced with 2 byte BCLR in 3rd)
      -----
      
      | 80b63324 <__dma_cache_wback_inv_l1>:
      | 80b63324:	clri	r3
      | 80b63328:	lr	r2,[dc_ctrl]
      | 80b6332c:	or	r2,r2,576
      | 80b63330:	sr	r2,[dc_ctrl]
      | ...
      | ...
      | 80b63358 <__dma_cache_inv_l1>:
      | 80b63358:	clri	r3
      | 80b6335c:	lr	r2,[dc_ctrl]
      | 80b63360:	bset_s	r2,r2,0x9
      | 80b63362:	sr	r2,[dc_ctrl]
      | ...
      | ...
      | 80b6337c <__dma_cache_wback_l1>:
      | 80b6337c:	clri	r3
      | 80b63380:	lr	r2,[dc_ctrl]
      | 80b63384:	bclr_s	r2,r2,0x9
      | 80b63386:	sr	r2,[dc_ctrl]
      Signed-off-by: NVineet Gupta <vgupta@synopsys.com>
      f734a310
    • V
      ARCv2: mm: Merge 2 updates to DC_CTRL for region flush · ee40bd1e
      Vineet Gupta 提交于
      Region Flush has a weird programming model.
      
       1. Flush or Invalidate is selected by DC_CTRL.RGN_OP
       2 Flush-n-Invalidate is done by DC_CTRL.IM
      
      Given the code structuring before, case #2 above was generating two
      seperate updates to DC_CTRL which was pointless.
      
      | 80a342b0 <__dma_cache_wback_inv_l1>:
      | 80a342b0:	clri	r4
      | 80a342b4:	lr	r2,[dc_ctrl]
      | 80a342b8:	bset_s	r2,r2,0x6
      | 80a342ba:	sr	r2,[dc_ctrl]	<-- FIRST
      |
      | 80a342be:	bmskn	r3,r0,0x5
      |
      | 80a342c2:	lr	r2,[dc_ctrl]
      | 80a342c6:	and	r2,r2,0xfffff1ff
      | 80a342ce:	bset_s	r2,r2,0x9
      | 80a342d0:	sr	r2,[dc_ctrl]	<-- SECOND
      |
      | 80a342d4:	add_s	r1,r1,0x3f
      | 80a342d6:	bmsk_s	r0,r0,0x5
      | 80a342d8:	add_s	r0,r0,r1
      | 80a342da:	add_s	r0,r0,r3
      | 80a342dc:	sr	r0,[78]
      | 80a342e0:	sr	r3,[77]
      |...
      |...
      
      So move setting of DC_CTRL.RGN_OP into __before_dc_op() and combine with
      any other update.
      
      | 80b63324 <__dma_cache_wback_inv_l1>:
      | 80b63324:	clri	r3
      | 80b63328:	lr	r2,[dc_ctrl]
      | 80b6332c:	and	r2,r2,0xfffff1ff
      | 80b63334:	or	r2,r2,576
      | 80b63338:	sr	r2,[dc_ctrl]
      |
      | 80b6333c:	add_s	r1,r1,0x3f
      | 80b6333e:	bmskn	r2,r0,0x5
      | 80b63342:	add_s	r0,r0,r1
      | 80b63344:	sr	r0,[78]
      | 80b63348:	sr	r2,[77]
      Signed-off-by: NVineet Gupta <vgupta@synopsys.com>
      ee40bd1e
    • V
      ARCv2: mm: Implement cache region flush operations · 0d77117f
      Vineet Gupta 提交于
      These are more efficient than the per-line ops
      Signed-off-by: NVineet Gupta <vgupta@synopsys.com>
      0d77117f
    • V
      ARC: mm: Move full_page computation into cache version agnostic wrapper · 7d3d162b
      Vineet Gupta 提交于
      This reduces code duplication in each of cache version specific handlers
      Signed-off-by: NVineet Gupta <vgupta@synopsys.com>
      7d3d162b
  2. 28 4月, 2017 2 次提交
  3. 21 4月, 2017 1 次提交
    • V
      ARCv2: entry: save Accumulator register pair (r58:59) if present · 3d5e8012
      Vineet Gupta 提交于
      Accumulator is present in configs with FPU and/or DSP MPY (mpy > 6)
      
      Instead of doing this in pt_regs (and thus every kernel entry/exit),
      this could have been done in context switch (and for user task only) as
      currently kernel doesn't clobber these registers for its own accord.
      However we will soon start using 64-bit multiply instructions for kernel
      which can clobber these. Also gcc folks also plan to start using these
      as GPRs, hence better to always save/restore them
      Signed-off-by: NVineet Gupta <vgupta@synopsys.com>
      3d5e8012
  4. 15 4月, 2017 1 次提交
  5. 10 4月, 2017 5 次提交
    • L
      Linux 4.11-rc6 · 39da7c50
      Linus Torvalds 提交于
      39da7c50
    • L
      Merge branch 'for-next' of git://git.samba.org/sfrench/cifs-2.6 · 84ced7fd
      Linus Torvalds 提交于
      Pull CIFS fixes from Steve French:
       "This is a set of CIFS/SMB3 fixes for stable.
      
        There is another set of four SMB3 reconnect fixes for stable in
        progress but they are still being reviewed/tested, so didn't want to
        wait any longer to send these five below"
      
      * 'for-next' of git://git.samba.org/sfrench/cifs-2.6:
        Reset TreeId to zero on SMB2 TREE_CONNECT
        CIFS: Fix build failure with smb2
        Introduce cifs_copy_file_range()
        SMB3: Rename clone_range to copychunk_range
        Handle mismatched open calls
      84ced7fd
    • L
      Merge branch 'fixes' of git://git.armlinux.org.uk/~rmk/linux-arm · 462e9a35
      Linus Torvalds 提交于
      Pull ARM fixes from Russell King:
       "A number of ARM fixes:
      
         - prevent oopses caused by dma_get_sgtable() and declared DMA
           coherent memory
      
         - fix boot failure on nommu caused by ID_PFR1 access
      
         - a number of kprobes fixes from Jon Medhurst and Masami Hiramatsu"
      
      * 'fixes' of git://git.armlinux.org.uk/~rmk/linux-arm:
        ARM: 8665/1: nommu: access ID_PFR1 only if CPUID scheme
        ARM: dma-mapping: disallow dma_get_sgtable() for non-kernel managed memory
        arm: kprobes: Align stack to 8-bytes in test code
        arm: kprobes: Fix the return address of multiple kretprobes
        arm: kprobes: Skip single-stepping in recursing path if possible
        arm: kprobes: Allow to handle reentered kprobe on single-stepping
      462e9a35
    • L
      Merge tag 'driver-core-4.11-rc6' of... · 5b50be74
      Linus Torvalds 提交于
      Merge tag 'driver-core-4.11-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core
      
      Pull driver core fixes from Greg KH:
       "Here are 3 small fixes for 4.11-rc6.
      
        One resolves a reported issue with sysfs files that NeilBrown found,
        one is a documenatation fix for the stable kernel rules, and the last
        is a small MAINTAINERS file update for kernfs"
      
      * tag 'driver-core-4.11-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core:
        MAINTAINERS: separate out kernfs maintainership
        sysfs: be careful of error returns from ops->show()
        Documentation: stable-kernel-rules: fix stable-tag format
      5b50be74
    • L
      Merge tag 'staging-4.11-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging · 62e1fd08
      Linus Torvalds 提交于
      Pull staging/IIO driver rfixes from Greg KH:
       "Here are a number of small IIO and staging driver fixes for 4.11-rc6.
        Nothing big here, just iio fixes for reported issues, and an ashmem
        fix for a very old bug that has been reported by a number of Android
        vendors"
      
      * tag 'staging-4.11-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging:
        staging: android: ashmem: lseek failed due to no FMODE_LSEEK.
        iio: hid-sensor-attributes: Fix sensor property setting failure.
        iio: accel: hid-sensor-accel-3d: Fix duplicate scan index error
        iio: core: Fix IIO_VAL_FRACTIONAL_LOG2 for negative values
        iio: st_pressure: initialize lps22hb bootime
        iio: bmg160: reset chip when probing
        iio: cros_ec_sensors: Fix return value to get raw and calibbias data.
      62e1fd08
  6. 09 4月, 2017 7 次提交
    • L
      Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs · 2a610b8a
      Linus Torvalds 提交于
      Pull VFS fixes from Al Viro:
       "statx followup fixes and a fix for stack-smashing on alpha"
      
      * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
        alpha: fix stack smashing in old_adjtimex(2)
        statx: Include a mask for stx_attributes in struct statx
        statx: Reserve the top bit of the mask for future struct expansion
        xfs: report crtime and attribute flags to statx
        ext4: Add statx support
        statx: optimize copy of struct statx to userspace
        statx: remove incorrect part of vfs_statx() comment
        statx: reject unknown flags when using NULL path
        Documentation/filesystems: fix documentation for ->getattr()
      2a610b8a
    • L
      Merge branch 'for-linus' of git://git.kernel.dk/linux-block · 78d91a75
      Linus Torvalds 提交于
      Pull block fixes from Jens Axboe:
       "Here's a pull request for 4.11-rc, fixing a set of issues mostly
        centered around the new scheduling framework. These have been brewing
        for a while, but split up into what we absolutely need in 4.11, and
        what we can defer until 4.12. These are well tested, on both single
        queue and multiqueue setups, and with and without shared tags. They
        fix several hangs that have happened in testing.
      
        This is obviously larger than I would have preferred at this point in
        time, but I don't think we can shave much off this and still get the
        desired results.
      
        In detail, this pull request contains:
      
         - a set of five fixes for NVMe, mostly from Christoph and one from
           Roland.
      
         - a series from Bart, fixing issues with dm-mq and SCSI shared tags
           and scheduling. Note that one of those patches commit messages may
           read like an optimization, but it is in fact an important fix for
           queue restarts in particular.
      
         - a series from Omar, most importantly fixing a hang with multiple
           hardware queues when we fail to get a driver tag. Another important
           fix in there is for resizing hardware queues, which nbd does when
           handling multiple sockets for one connection.
      
         - fixing an imbalance in putting the ctx for hctx request allocations
           from Minchan"
      
      * 'for-linus' of git://git.kernel.dk/linux-block:
        blk-mq: Restart a single queue if tag sets are shared
        dm rq: Avoid that request processing stalls sporadically
        scsi: Avoid that SCSI queues get stuck
        blk-mq: Introduce blk_mq_delay_run_hw_queue()
        blk-mq: remap queues when adding/removing hardware queues
        blk-mq-sched: fix crash in switch error path
        blk-mq-sched: set up scheduler tags when bringing up new queues
        blk-mq-sched: refactor scheduler initialization
        blk-mq: use the right hctx when getting a driver tag fails
        nvmet: fix byte swap in nvmet_parse_io_cmd
        nvmet: fix byte swap in nvmet_execute_write_zeroes
        nvmet: add missing byte swap in nvmet_get_smart_log
        nvme: add missing byte swap in nvme_setup_discard
        nvme: Correct NVMF enum values to match NVMe-oF rev 1.0
        block: do not put mq context in blk_mq_alloc_request_hctx
      78d91a75
    • L
      Merge tag 'pinctrl-v4.11-4' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl · c3df1c7c
      Linus Torvalds 提交于
      Pull pin control fix from Linus Walleij:
       "This late fix for pin control is hopefully the last I send this cycle.
      
        The problem was detected early in the v4.11 release cycle and there
        has been some back and forth on how to solve it. Sadly the proper fix
        arrives late, but at least not too late.
      
        An issue was detected with pin control on the Freescale i.MX after the
        refactorings for more general group and function handling.
      
        We now have the proper fix for this"
      
      * tag 'pinctrl-v4.11-4' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl:
        pinctrl: core: Fix pinctrl_register_and_init() with pinctrl_enable()
      c3df1c7c
    • L
      Merge tag 'powerpc-4.11-7' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux · 894ca30c
      Linus Torvalds 提交于
      Pull powerpc fixes from Michael Ellerman:
       "Some more powerpc fixes for 4.11:
      
        Headed to stable:
      
         - disable HFSCR[TM] if TM is not supported, fixes a potential host
           kernel crash triggered by a hostile guest, but only in
           configurations that no one uses
      
         - don't try to fix up misaligned load-with-reservation instructions
      
         - fix flush_(d|i)cache_range() called from modules on little endian
           kernels
      
         - add missing global TLB invalidate if cxl is active
      
         - fix missing preempt_disable() in crc32c-vpmsum
      
        And a fix for selftests build changes that went in this release:
      
         - selftests/powerpc: Fix standalone powerpc build
      
        Thanks to: Benjamin Herrenschmidt, Frederic Barrat, Oliver O'Halloran,
        Paul Mackerras"
      
      * tag 'powerpc-4.11-7' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux:
        powerpc/crypto/crc32c-vpmsum: Fix missing preempt_disable()
        powerpc/mm: Add missing global TLB invalidate if cxl is active
        powerpc/64: Fix flush_(d|i)cache_range() called from modules
        powerpc: Don't try to fix up misaligned load-with-reservation instructions
        powerpc: Disable HFSCR[TM] if TM is not supported
        selftests/powerpc: Fix standalone powerpc build
      894ca30c
    • C
      mm/mempolicy.c: fix error handling in set_mempolicy and mbind. · cf01fb99
      Chris Salls 提交于
      In the case that compat_get_bitmap fails we do not want to copy the
      bitmap to the user as it will contain uninitialized stack data and leak
      sensitive data.
      Signed-off-by: NChris Salls <salls@cs.ucsb.edu>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      cf01fb99
    • L
      sysctl: report EINVAL if value is larger than UINT_MAX for proc_douintvec · 425fffd8
      Liping Zhang 提交于
      Currently, inputting the following command will succeed but actually the
      value will be truncated:
      
        # echo 0x12ffffffff > /proc/sys/net/ipv4/tcp_notsent_lowat
      
      This is not friendly to the user, so instead, we should report error
      when the value is larger than UINT_MAX.
      
      Fixes: e7d316a0 ("sysctl: handle error writing UINT_MAX to u32 fields")
      Signed-off-by: NLiping Zhang <zlpnobody@gmail.com>
      Cc: Subash Abhinov Kasiviswanathan <subashab@codeaurora.org>
      Cc: Andrew Morton <akpm@linux-foundation.org>
      Cc: Eric W. Biederman <ebiederm@xmission.com>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      425fffd8
    • T
      MAINTAINERS: separate out kernfs maintainership · 27f395b8
      Tejun Heo 提交于
      Separate out kernfs from driver core and add myself as a
      co-maintainer.
      Signed-off-by: NTejun Heo <tj@kernel.org>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      27f395b8
  7. 08 4月, 2017 20 次提交
新手
引导
客服 返回
顶部