1. 13 12月, 2019 40 次提交
    • C
      rtc: max77686: Fix the returned value in case of error in 'max77686_rtc_read_time()' · 2538bbb0
      Christophe JAILLET 提交于
      [ Upstream commit b28cc6cec3d814f5184cbebb2d1f987e769f534a ]
      
      In case of error, we return 0.
      This is spurious and not consistent with the other functions of the driver.
      Commit e115a2bf has modified more than what is said in the commit
      message. Reverse part of it znd return an error when needed, as it was
      previously.
      
      Fixes: e115a2bf ("rtc: max77686: stop validating rtc_time in .read_time")
      Signed-off-by: NChristophe JAILLET <christophe.jaillet@wanadoo.fr>
      Reviewed-by: NChanwoo Choi <cw00.choi@samsung.com>
      Signed-off-by: NAlexandre Belloni <alexandre.belloni@bootlin.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      2538bbb0
    • M
      rtc: s3c-rtc: Avoid using broken ALMYEAR register · eb5b255e
      Marek Szyprowski 提交于
      [ Upstream commit 50c8aec4212a966817e868056efc9bfbb73337c0 ]
      
      (RTC,ALM)YEAR registers of Exynos built-in RTC device contains 3 BCD
      characters. s3c-rtc driver uses only 2 lower of them and supports years
      from 2000..2099 range. The third BCD value is typically set to 0, but it
      looks that handling of it is broken in the hardware. It sometimes
      defaults to a random (even non-BCD) value. This is not an issue
      for handling RTCYEAR register, because bcd2bin() properly handles only
      8bit values (2 BCD characters, the third one is skipped). The problem
      is however with ALMYEAR register and proper RTC alarm operation. When
      YEAREN bit is set for the configured alarm, RTC hardware triggers alarm
      only when ALMYEAR and RTCYEAR matches. This usually doesn't happen
      because of the random noise on the third BCD character.
      
      Fix this by simply skipping setting ALMYEAR register in alarm
      configuration. This workaround fixes broken alarm operation on Exynos
      built-in rtc device. My tests revealed that the issue happens on the
      following Exynos series: 3250, 4210, 4412, 5250 and 5410.
      Signed-off-by: NMarek Szyprowski <m.szyprowski@samsung.com>
      Signed-off-by: NAlexandre Belloni <alexandre.belloni@bootlin.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      eb5b255e
    • I
      net: ethernet: ti: cpts: correct debug for expired txq skb · 22a6ec0a
      Ivan Khoronzhuk 提交于
      [ Upstream commit d0e14c4d9bcef0d4aa1057d2959adaa6f18d4a17 ]
      
      The msgtype and seqid that is smth that belongs to event for
      comparison but not for staled txq skb.
      Signed-off-by: NIvan Khoronzhuk <ivan.khoronzhuk@linaro.org>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      22a6ec0a
    • M
      extcon: max8997: Fix lack of path setting in USB device mode · 644fde1c
      Marek Szyprowski 提交于
      [ Upstream commit a2dc50914744eea9f83a70a5db0486be625e5dc0 ]
      
      MAX8997 driver disables automatic path selection from MicroUSB connector
      and manually sets path to either UART or USB lines. However the code for
      setting USB path worked only for USB host mode (when ID pin is set
      to ground). When standard USB cable (USB device mode) is connected, path
      registers are not touched. This means that once the non-USB accessory is
      connected to MAX8997-operated micro USB port, the path is no longer set
      to USB and USB device mode doesn't work. This patch fixes it by setting
      USB path both for USB and USB host modes.
      Signed-off-by: NMarek Szyprowski <m.szyprowski@samsung.com>
      Signed-off-by: NChanwoo Choi <cw00.choi@samsung.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      644fde1c
    • A
      ARM: dts: exynos: Fix LDO13 min values on Odroid XU3/XU4/HC1 · 2c0ba770
      Anand Moon 提交于
      [ Upstream commit 8fe325fa9d065aa54db4914fdaccab2169fd67a8 ]
      
      From Odroid XU3/XU4/HC1 schematics the LDO13 regulator for SD2, can be
      set on 1.8V or 2.8V so the minimal value should be fixed to 1.8V.  This
      is necessary to support UHS-I tuning (otherwise card won't be detected
      during boot).
      Signed-off-by: NAnand Moon <linux.amoon@gmail.com>
      Signed-off-by: NKrzysztof Kozlowski <krzk@kernel.org>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      2c0ba770
    • D
      dlm: fix possible call to kfree() for non-initialized pointer · ed224150
      Denis V. Lunev 提交于
      [ Upstream commit 58a923adf4d9aca8bf7205985c9c8fc531c65d72 ]
      
      Technically dlm_config_nodes() could return error and keep nodes
      uninitialized. After that on the fail path of we'll call kfree()
      for that uninitialized value.
      
      The patch is simple - we should just initialize nodes with NULL.
      Signed-off-by: NDenis V. Lunev <den@openvz.org>
      Signed-off-by: NDavid Teigland <teigland@redhat.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      ed224150
    • L
      ice: Fix NVM mask defines · fd12b061
      Lev Faerman 提交于
      [ Upstream commit 6263e811f4d4418660c20b36a08063c6d2c3fb9d ]
      
      Fixes bad masks that would break compilation when evaluated.
      Signed-off-by: NLev Faerman <lev.faerman@intel.com>
      Signed-off-by: NAnirudh Venkataramanan <anirudh.venkataramanan@intel.com>
      Tested-by: NAndrew Bowers <andrewx.bowers@intel.com>
      Signed-off-by: NJeff Kirsher <jeffrey.t.kirsher@intel.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      fd12b061
    • J
      clk: sunxi-ng: a64: Fix gate bit of DSI DPHY · ac3750e9
      Jagan Teki 提交于
      [ Upstream commit ee678706e46d0d185c27cc214ad97828e0643159 ]
      
      DSI DPHY gate bit on MIPI DSI clock register is bit 15
      not bit 30.
      Signed-off-by: NJagan Teki <jagan@amarulasolutions.com>
      Acked-by: NStephen Boyd <sboyd@kernel.org>
      Signed-off-by: NMaxime Ripard <maxime.ripard@bootlin.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      ac3750e9
    • M
      net/mlx5: Release resource on error flow · a26a4469
      Moni Shoua 提交于
      [ Upstream commit 698114968a22f6c0c9f42e983ba033cc36bb7217 ]
      
      Fix reference counting leakage when the event handler aborts due to an
      unsupported event for the resource type.
      
      Fixes: a14c2d4b ("net/mlx5_core: Warn on unsupported events of QP/RQ/SQ")
      Signed-off-by: NMoni Shoua <monis@mellanox.com>
      Reviewed-by: NMajd Dibbiny <majd@mellanox.com>
      Signed-off-by: NLeon Romanovsky <leonro@mellanox.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      a26a4469
    • E
      ARC: IOC: panic if kernel was started with previously enabled IOC · 705d1e73
      Eugeniy Paltsev 提交于
      [ Upstream commit 3624379d90ad2b65f9dbb30d7f7ce5498d2fe322 ]
      
      If IOC was already enabled (due to bootloader) it technically needs to
      be reconfigured with aperture base,size corresponding to Linux memory map
      which will certainly be different than uboot's. But disabling and
      reenabling IOC when DMA might be potentially active is tricky business.
      To avoid random memory issues later, just panic here and ask user to
      upgrade bootloader to one which doesn't enable IOC
      
      This was actually seen as issue on some of the HSDK board with a version
      of uboot which enabled IOC. There were random issues later with starting
      of X or peripherals etc.
      
      Also while I'm at it, replace hardcoded bits in ARC_REG_IO_COH_PARTIAL
      and ARC_REG_IO_COH_ENABLE registers by definitions.
      
      Inspired by: https://lkml.org/lkml/2018/1/19/557Signed-off-by: NEugeniy Paltsev <Eugeniy.Paltsev@synopsys.com>
      Signed-off-by: NVineet Gupta <vgupta@synopsys.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      705d1e73
    • F
      netfilter: nf_tables: don't use position attribute on rule replacement · 2d484087
      Florian Westphal 提交于
      [ Upstream commit 447750f281abef547be44fdcfe3bc4447b3115a8 ]
      
      Its possible to set both HANDLE and POSITION when replacing a rule.
      In this case, the rule at POSITION gets replaced using the
      userspace-provided handle.  Rule handles are supposed to be generated
      by the kernel only.
      
      Duplicate handles should be harmless, however better disable this "feature"
      by only checking for the POSITION attribute on insert operations.
      
      Fixes: 5e948466 ("netfilter: nf_tables: add insert operation")
      Signed-off-by: NFlorian Westphal <fw@strlen.de>
      Signed-off-by: NPablo Neira Ayuso <pablo@netfilter.org>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      2d484087
    • J
      audit: Embed key into chunk · 6ce317fd
      Jan Kara 提交于
      [ Upstream commit 8d20d6e9301d7b3777d66d47dd5b89acd645cd39 ]
      
      Currently chunk hash key (which is in fact pointer to the inode) is
      derived as chunk->mark.conn->obj. It is tricky to make this dereference
      reliable for hash table lookups only under RCU as mark can get detached
      from the connector and connector gets freed independently of the
      running lookup. Thus there is a possible use after free / NULL ptr
      dereference issue:
      
      CPU1					CPU2
      					untag_chunk()
      					  ...
      audit_tree_lookup()
        list_for_each_entry_rcu(p, list, hash) {
      					  list_del_rcu(&chunk->hash);
      					  fsnotify_destroy_mark(entry);
      					  fsnotify_put_mark(entry)
          chunk_to_key(p)
            if (!chunk->mark.connector)
      					    ...
      					    hlist_del_init_rcu(&mark->obj_list);
      					    if (hlist_empty(&conn->list)) {
      					      inode = fsnotify_detach_connector_from_object(conn);
      					    mark->connector = NULL;
      					    ...
      					    frees connector from workqueue
            chunk->mark.connector->obj
      
      This race is probably impossible to hit in practice as the race window
      on CPU1 is very narrow and CPU2 has a lot of code to execute. Still it's
      better to have this fixed. Since the inode the chunk is attached to is
      constant during chunk's lifetime it is easy to cache the key in the
      chunk itself and thus avoid these issues.
      Reviewed-by: NRichard Guy Briggs <rgb@redhat.com>
      Signed-off-by: NJan Kara <jack@suse.cz>
      Signed-off-by: NPaul Moore <paul@paul-moore.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      6ce317fd
    • V
      ARM: 8813/1: Make aligned 2-byte getuser()/putuser() atomic on ARMv6+ · b8252ec6
      Vincent Whitchurch 提交于
      [ Upstream commit 344eb5539abf3e0b6ce22568c03e86450073e097 ]
      
      getuser() and putuser() (and there underscored variants) use two
      strb[t]/ldrb[t] instructions when they are asked to get/put 16-bits.
      This means that the read/write is not atomic even when performed to a
      16-bit-aligned address.
      
      This leads to problems with vhost: vhost uses __getuser() to read the
      vring's 16-bit avail.index field, and if it happens to observe a partial
      update of the index, wrong descriptors will be used which will lead to a
      breakdown of the virtio communication.  A similar problem exists for
      __putuser() which is used to write to the vring's used.index field.
      
      The reason these functions use strb[t]/ldrb[t] is because strht/ldrht
      instructions did not exist until ARMv6T2/ARMv7.  So we should be easily
      able to fix this on ARMv7.  Also, since all ARMv6 processors also don't
      actually use the unprivileged instructions anymore for uaccess (since
      CONFIG_CPU_USE_DOMAINS is not used) we can easily fix them too.
      Signed-off-by: NVincent Whitchurch <vincent.whitchurch@axis.com>
      Signed-off-by: NRussell King <rmk+kernel@armlinux.org.uk>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      b8252ec6
    • A
      iwlwifi: mvm: Send non offchannel traffic via AP sta · d0426a34
      Andrei Otcheretianski 提交于
      [ Upstream commit dc1aca22f8f38b7e2ad7b118db87404d11e68771 ]
      
      TDLS discovery response frame is a unicast direct frame to the peer.
      Since we don't have a STA for this peer, this frame goes through
      iwl_tx_skb_non_sta(). As the result aux_sta and some completely
      arbitrary queue would be selected for this frame, resulting in a queue
      hang.  Fix that by sending such frames through AP sta instead.
      Signed-off-by: NAndrei Otcheretianski <andrei.otcheretianski@intel.com>
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      d0426a34
    • S
      iwlwifi: trans: Clear persistence bit when starting the FW · 698d71cb
      Shahar S Matityahu 提交于
      [ Upstream commit 8954e1eb2270fa2effffd031b4839253952c76f2 ]
      
      In D3 suspend flow in 9260 gen2 HW, the NIC receives two PERST signals.
      The first PERST is expected and indicates the device on coming resume flow.
      The second PERST causes FW restart FW restart.
      In order to avoid this issue, the FW set the persistence bit on.
      Once this bit is set, the FW ignores reset attempts.
      The problem is when the FW gets assert during D3 and then the persistence
      bit is set and causes the FW to ignore reset.
      To handle this issue, the FW opens the preg bit which allows access
      to the persistence bit, so that the driver clear the persistence bit
      and reset the NIC.
      
      The flow is as follows:
      the driver checks if the persistence bit is set.
      If the bit is set, the driver checks if he can clear the bit.
      If the driver can not clear the bit then there is no point to continue
      configuring the NIC since it will fail.
      
      The fix was added is in start HW flow instead of the resume flow since in
      general, if the persistence bit is set, the driver can not start the FW.
      So it is good to check it when we start configuring the NIC.
      
      The driver does not need to close the preg bit since the FW close it
      during the start flow.
      Signed-off-by: NShahar S Matityahu <shahar.s.matityahu@intel.com>
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      698d71cb
    • J
      iwlwifi: mvm: synchronize TID queue removal · 26632a07
      Johannes Berg 提交于
      [ Upstream commit 06bc6f6ed4ae0246a5e52094d1be90906a1361c7 ]
      
      When we mark a TID as no longer having a queue, there's no
      guarantee the TX path isn't using this txq_id right now,
      having accessed it just before we reset the value. To fix
      this, add synchronize_net() when we change the TIDs from
      having a queue to not having one, so that we can then be
      sure that the TX path is no longer accessing that queue.
      Signed-off-by: NJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      26632a07
    • A
      cxgb4vf: fix memleak in mac_hlist initialization · cdec9eec
      Arjun Vynipadath 提交于
      [ Upstream commit 24357e06ba511ad874d664d39475dbb01c1ca450 ]
      
      mac_hlist was initialized during adapter_up, which will be called
      every time a vf device is first brought up, or every time when device
      is brought up again after bringing all devices down. This means our
      state of previous list is lost, causing a memleak if entries are
      present in the list. To fix that, move list init to the condition
      that performs initial one time adapter setup.
      Signed-off-by: NArjun Vynipadath <arjun@chelsio.com>
      Signed-off-by: NGanesh Goudar <ganeshgr@chelsio.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      cdec9eec
    • D
      serial: core: Allow processing sysrq at port unlock time · 2c299a22
      Douglas Anderson 提交于
      [ Upstream commit d6e1935819db0c91ce4a5af82466f3ab50d17346 ]
      
      Right now serial drivers process sysrq keys deep in their character
      receiving code.  This means that they've already grabbed their
      port->lock spinlock.  This can end up getting in the way if we've go
      to do serial stuff (especially kgdb) in response to the sysrq.
      
      Serial drivers have various hacks in them to handle this.  Looking at
      '8250_port.c' you can see that the console_write() skips locking if
      we're in the sysrq handler.  Looking at 'msm_serial.c' you can see
      that the port lock is dropped around uart_handle_sysrq_char().
      
      It turns out that these hacks aren't exactly perfect.  If you have
      lockdep turned on and use something like the 8250_port hack you'll get
      a splat that looks like:
      
        WARNING: possible circular locking dependency detected
        [...] is trying to acquire lock:
        ... (console_owner){-.-.}, at: console_unlock+0x2e0/0x5e4
      
        but task is already holding lock:
        ... (&port_lock_key){-.-.}, at: serial8250_handle_irq+0x30/0xe4
      
        which lock already depends on the new lock.
      
        the existing dependency chain (in reverse order) is:
      
        -> #1 (&port_lock_key){-.-.}:
               _raw_spin_lock_irqsave+0x58/0x70
               serial8250_console_write+0xa8/0x250
               univ8250_console_write+0x40/0x4c
               console_unlock+0x528/0x5e4
               register_console+0x2c4/0x3b0
               uart_add_one_port+0x350/0x478
               serial8250_register_8250_port+0x350/0x3a8
               dw8250_probe+0x67c/0x754
               platform_drv_probe+0x58/0xa4
               really_probe+0x150/0x294
               driver_probe_device+0xac/0xe8
               __driver_attach+0x98/0xd0
               bus_for_each_dev+0x84/0xc8
               driver_attach+0x2c/0x34
               bus_add_driver+0xf0/0x1ec
               driver_register+0xb4/0x100
               __platform_driver_register+0x60/0x6c
               dw8250_platform_driver_init+0x20/0x28
      	 ...
      
        -> #0 (console_owner){-.-.}:
               lock_acquire+0x1e8/0x214
               console_unlock+0x35c/0x5e4
               vprintk_emit+0x230/0x274
               vprintk_default+0x7c/0x84
               vprintk_func+0x190/0x1bc
               printk+0x80/0xa0
               __handle_sysrq+0x104/0x21c
               handle_sysrq+0x30/0x3c
               serial8250_read_char+0x15c/0x18c
               serial8250_rx_chars+0x34/0x74
               serial8250_handle_irq+0x9c/0xe4
               dw8250_handle_irq+0x98/0xcc
               serial8250_interrupt+0x50/0xe8
               ...
      
        other info that might help us debug this:
      
         Possible unsafe locking scenario:
      
               CPU0                    CPU1
               ----                    ----
          lock(&port_lock_key);
                                       lock(console_owner);
                                       lock(&port_lock_key);
          lock(console_owner);
      
         *** DEADLOCK ***
      
      The hack used in 'msm_serial.c' doesn't cause the above splats but it
      seems a bit ugly to unlock / lock our spinlock deep in our irq
      handler.
      
      It seems like we could defer processing the sysrq until the end of the
      interrupt handler right after we've unlocked the port.  With this
      scheme if a whole batch of sysrq characters comes in one irq then we
      won't handle them all, but that seems like it should be a fine
      compromise.
      Signed-off-by: NDouglas Anderson <dianders@chromium.org>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      2c299a22
    • W
      i2c: core: fix use after free in of_i2c_notify · c3563c3e
      Wen Yang 提交于
      [ Upstream commit a4c2fec16f5e6a5fee4865e6e0e91e2bc2d10f37 ]
      
      We can't use "adap->dev" after it has been freed.
      
      Fixes: 5bf4fa7d ("i2c: break out OF support into separate file")
      Signed-off-by: NWen Yang <wenyang@linux.alibaba.com>
      Signed-off-by: NWolfram Sang <wsa@the-dreams.de>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      c3563c3e
    • C
      net: ep93xx_eth: fix mismatch of request_mem_region in remove · d228e1e3
      Chuhong Yuan 提交于
      [ Upstream commit 3df70afe8d33f4977d0e0891bdcfb639320b5257 ]
      
      The driver calls release_resource in remove to match request_mem_region
      in probe, which is incorrect.
      Fix it by using the right one, release_mem_region.
      Signed-off-by: NChuhong Yuan <hslester96@gmail.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      d228e1e3
    • C
      rsxx: add missed destroy_workqueue calls in remove · 6eb6e800
      Chuhong Yuan 提交于
      [ Upstream commit dcb77e4b274b8f13ac6482dfb09160cd2fae9a40 ]
      
      The driver misses calling destroy_workqueue in remove like what is done
      when probe fails.
      Add the missed calls to fix it.
      Signed-off-by: NChuhong Yuan <hslester96@gmail.com>
      Signed-off-by: NJens Axboe <axboe@kernel.dk>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      6eb6e800
    • V
      selftests: kvm: fix build with glibc >= 2.30 · a806e2a3
      Vitaly Kuznetsov 提交于
      [ Upstream commit e37f9f139f62deddff90c7298ae3a85026a71067 ]
      
      Glibc-2.30 gained gettid() wrapper, selftests fail to compile:
      
      lib/assert.c:58:14: error: static declaration of ‘gettid’ follows non-static declaration
         58 | static pid_t gettid(void)
            |              ^~~~~~
      In file included from /usr/include/unistd.h:1170,
                       from include/test_util.h:18,
                       from lib/assert.c:10:
      /usr/include/bits/unistd_ext.h:34:16: note: previous declaration of ‘gettid’ was here
         34 | extern __pid_t gettid (void) __THROW;
            |                ^~~~~~
      Signed-off-by: NVitaly Kuznetsov <vkuznets@redhat.com>
      Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      a806e2a3
    • Y
      drm/sun4i: tcon: Set min division of TCON0_DCLK to 1. · 15479dd1
      Yunhao Tian 提交于
      [ Upstream commit 0b8e7bbde5e7e2c419567e1ee29587dae3b78ee3 ]
      
      The datasheet of V3s (and various other chips) wrote
      that TCON0_DCLK_DIV can be >= 1 if only dclk is used,
      and must >= 6 if dclk1 or dclk2 is used. As currently
      neither dclk1 nor dclk2 is used (no writes to these
      bits), let's set minimal division to 1.
      
      If this minimal division is 6, some common dot clock
      frequencies can't be produced (e.g. 30MHz will not be
      possible and will fallback to 25MHz), which is
      obviously not an expected behaviour.
      Signed-off-by: NYunhao Tian <t123yh@outlook.com>
      Signed-off-by: NMaxime Ripard <maxime@cerno.tech>
      Link: https://lore.kernel.org/linux-arm-kernel/MN2PR08MB57905AD8A00C08DA219377C989760@MN2PR08MB5790.namprd08.prod.outlook.com/Signed-off-by: NSasha Levin <sashal@kernel.org>
      15479dd1
    • P
      ALSA: pcm: Fix stream lock usage in snd_pcm_period_elapsed() · e41ca81e
      paulhsia 提交于
      [ Upstream commit f5cdc9d4003a2f66ea57b3edd3e04acc2b1a4439 ]
      
      If the nullity check for `substream->runtime` is outside of the lock
      region, it is possible to have a null runtime in the critical section
      if snd_pcm_detach_substream is called right before the lock.
      Signed-off-by: Npaulhsia <paulhsia@chromium.org>
      Link: https://lore.kernel.org/r/20191112171715.128727-2-paulhsia@chromium.orgSigned-off-by: NTakashi Iwai <tiwai@suse.de>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      e41ca81e
    • A
      perf/core: Consistently fail fork on allocation failures · 78a917be
      Alexander Shishkin 提交于
      [ Upstream commit 697d877849d4b34ab58d7078d6930bad0ef6fc66 ]
      
      Commit:
      
        313ccb96 ("perf: Allocate context task_ctx_data for child event")
      
      makes the inherit path skip over the current event in case of task_ctx_data
      allocation failure. This, however, is inconsistent with allocation failures
      in perf_event_alloc(), which would abort the fork.
      
      Correct this by returning an error code on task_ctx_data allocation
      failure and failing the fork in that case.
      Signed-off-by: NAlexander Shishkin <alexander.shishkin@linux.intel.com>
      Signed-off-by: NPeter Zijlstra (Intel) <peterz@infradead.org>
      Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
      Cc: David Ahern <dsahern@gmail.com>
      Cc: Jiri Olsa <jolsa@kernel.org>
      Cc: Jiri Olsa <jolsa@redhat.com>
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      Cc: Mark Rutland <mark.rutland@arm.com>
      Cc: Namhyung Kim <namhyung@kernel.org>
      Cc: Stephane Eranian <eranian@google.com>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: Vince Weaver <vincent.weaver@maine.edu>
      Link: https://lkml.kernel.org/r/20191105075702.60319-1-alexander.shishkin@linux.intel.comSigned-off-by: NIngo Molnar <mingo@kernel.org>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      78a917be
    • P
      sched/core: Avoid spurious lock dependencies · 870083b6
      Peter Zijlstra 提交于
      [ Upstream commit ff51ff84d82aea5a889b85f2b9fb3aa2b8691668 ]
      
      While seemingly harmless, __sched_fork() does hrtimer_init(), which,
      when DEBUG_OBJETS, can end up doing allocations.
      
      This then results in the following lock order:
      
        rq->lock
          zone->lock.rlock
            batched_entropy_u64.lock
      
      Which in turn causes deadlocks when we do wakeups while holding that
      batched_entropy lock -- as the random code does.
      
      Solve this by moving __sched_fork() out from under rq->lock. This is
      safe because nothing there relies on rq->lock, as also evident from the
      other __sched_fork() callsite.
      Signed-off-by: NPeter Zijlstra (Intel) <peterz@infradead.org>
      Cc: Linus Torvalds <torvalds@linux-foundation.org>
      Cc: Peter Zijlstra <peterz@infradead.org>
      Cc: Qian Cai <cai@lca.pw>
      Cc: Thomas Gleixner <tglx@linutronix.de>
      Cc: akpm@linux-foundation.org
      Cc: bigeasy@linutronix.de
      Cc: cl@linux.com
      Cc: keescook@chromium.org
      Cc: penberg@kernel.org
      Cc: rientjes@google.com
      Cc: thgarnie@google.com
      Cc: tytso@mit.edu
      Cc: will@kernel.org
      Fixes: b7d5dc21072c ("random: add a spinlock_t to struct batched_entropy")
      Link: https://lkml.kernel.org/r/20191001091837.GK4536@hirez.programming.kicks-ass.netSigned-off-by: NIngo Molnar <mingo@kernel.org>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      870083b6
    • P
      Input: cyttsp4_core - fix use after free bug · 41415da3
      Pan Bian 提交于
      [ Upstream commit 79aae6acbef16f720a7949f8fc6ac69816c79d62 ]
      
      The device md->input is used after it is released. Setting the device
      data to NULL is unnecessary as the device is never used again. Instead,
      md->input should be assigned NULL to avoid accessing the freed memory
      accidently. Besides, checking md->si against NULL is superfluous as it
      points to a variable address, which cannot be NULL.
      Signed-off-by: NPan Bian <bianpan2016@163.com>
      Link: https://lore.kernel.org/r/1572936379-6423-1-git-send-email-bianpan2016@163.comSigned-off-by: NDmitry Torokhov <dmitry.torokhov@gmail.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      41415da3
    • X
      xfrm: release device reference for invalid state · e31f97a0
      Xiaodong Xu 提交于
      [ Upstream commit 4944a4b1077f74d89073624bd286219d2fcbfce3 ]
      
      An ESP packet could be decrypted in async mode if the input handler for
      this packet returns -EINPROGRESS in xfrm_input(). At this moment the device
      reference in skb is held. Later xfrm_input() will be invoked again to
      resume the processing.
      If the transform state is still valid it would continue to release the
      device reference and there won't be a problem; however if the transform
      state is not valid when async resumption happens, the packet will be
      dropped while the device reference is still being held.
      When the device is deleted for some reason and the reference to this
      device is not properly released, the kernel will keep logging like:
      
      unregister_netdevice: waiting for ppp2 to become free. Usage count = 1
      
      The issue is observed when running IPsec traffic over a PPPoE device based
      on a bridge interface. By terminating the PPPoE connection on the server
      end for multiple times, the PPPoE device on the client side will eventually
      get stuck on the above warning message.
      
      This patch will check the async mode first and continue to release device
      reference in async resumption, before it is dropped due to invalid state.
      
      v2: Do not assign address family from outer_mode in the transform if the
      state is invalid
      
      v3: Release device reference in the error path instead of jumping to resume
      
      Fixes: 4ce3dbe3 ("xfrm: Fix xfrm_input() to verify state is valid when (encap_type < 0)")
      Signed-off-by: NXiaodong Xu <stid.smth@gmail.com>
      Reported-by: NBo Chen <chenborfc@163.com>
      Tested-by: NBo Chen <chenborfc@163.com>
      Signed-off-by: NSteffen Klassert <steffen.klassert@secunet.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      e31f97a0
    • S
      NFC: nxp-nci: Fix NULL pointer dereference after I2C communication error · 3c5f6ba0
      Stephan Gerhold 提交于
      [ Upstream commit a71a29f50de1ef97ab55c151a1598eb12dde379d ]
      
      I2C communication errors (-EREMOTEIO) during the IRQ handler of nxp-nci
      result in a NULL pointer dereference at the moment:
      
          BUG: kernel NULL pointer dereference, address: 0000000000000000
          Oops: 0002 [#1] PREEMPT SMP NOPTI
          CPU: 1 PID: 355 Comm: irq/137-nxp-nci Not tainted 5.4.0-rc6 #1
          RIP: 0010:skb_queue_tail+0x25/0x50
          Call Trace:
           nci_recv_frame+0x36/0x90 [nci]
           nxp_nci_i2c_irq_thread_fn+0xd1/0x285 [nxp_nci_i2c]
           ? preempt_count_add+0x68/0xa0
           ? irq_forced_thread_fn+0x80/0x80
           irq_thread_fn+0x20/0x60
           irq_thread+0xee/0x180
           ? wake_threads_waitq+0x30/0x30
           kthread+0xfb/0x130
           ? irq_thread_check_affinity+0xd0/0xd0
           ? kthread_park+0x90/0x90
           ret_from_fork+0x1f/0x40
      
      Afterward the kernel must be rebooted to work properly again.
      
      This happens because it attempts to call nci_recv_frame() with skb == NULL.
      However, unlike nxp_nci_fw_recv_frame(), nci_recv_frame() does not have any
      NULL checks for skb, causing the NULL pointer dereference.
      
      Change the code to call only nxp_nci_fw_recv_frame() in case of an error.
      Make sure to log it so it is obvious that a communication error occurred.
      The error above then becomes:
      
          nxp-nci_i2c i2c-NXP1001:00: NFC: Read failed with error -121
          nci: __nci_request: wait_for_completion_interruptible_timeout failed 0
          nxp-nci_i2c i2c-NXP1001:00: NFC: Read failed with error -121
      
      Fixes: 6be88670 ("NFC: nxp-nci_i2c: Add I2C support to NXP NCI driver")
      Signed-off-by: NStephan Gerhold <stephan@gerhold.net>
      Reviewed-by: NAndy Shevchenko <andriy.shevchenko@linux.intel.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      3c5f6ba0
    • A
      audit_get_nd(): don't unlock parent too early · 7fb6ef16
      Al Viro 提交于
      [ Upstream commit 69924b89687a2923e88cc42144aea27868913d0e ]
      
      if the child has been negative and just went positive
      under us, we want coherent d_is_positive() and ->d_inode.
      Don't unlock the parent until we'd done that work...
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      7fb6ef16
    • A
      exportfs_decode_fh(): negative pinned may become positive without the parent locked · af17e1fc
      Al Viro 提交于
      [ Upstream commit a2ece088882666e1dc7113744ac912eb161e3f87 ]
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      af17e1fc
    • M
      iwlwifi: pcie: don't consider IV len in A-MSDU · dadd71d1
      Mordechay Goodstein 提交于
      [ Upstream commit cb1a4badf59275eb7221dcec621e8154917eabd1 ]
      
      From gen2 PN is totally offloaded to hardware (also the space for the
      IV isn't part of the skb).  As you can see in mvm/mac80211.c:3545, the
      MAC for cipher types CCMP/GCMP doesn't set
      IEEE80211_KEY_FLAG_PUT_IV_SPACE for gen2 NICs.
      
      This causes all the AMSDU data to be corrupted with cipher enabled.
      Signed-off-by: NMordechay Goodstein <mordechay.goodstein@intel.com>
      Signed-off-by: NLuca Coelho <luciano.coelho@intel.com>
      Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      dadd71d1
    • S
      RDMA/hns: Correct the value of HNS_ROCE_HEM_CHUNK_LEN · 65e5e991
      Sirong Wang 提交于
      [ Upstream commit 531eb45b3da4267fc2a64233ba256c8ffb02edd2 ]
      
      Size of pointer to buf field of struct hns_roce_hem_chunk should be
      considered when calculating HNS_ROCE_HEM_CHUNK_LEN, or sg table size will
      be larger than expected when allocating hem.
      
      Fixes: 9a443537 ("IB/hns: Add driver files for hns RoCE driver")
      Link: https://lore.kernel.org/r/1572575610-52530-2-git-send-email-liweihang@hisilicon.comSigned-off-by: NSirong Wang <wangsirong@huawei.com>
      Signed-off-by: NWeihang Li <liweihang@hisilicon.com>
      Signed-off-by: NJason Gunthorpe <jgg@mellanox.com>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      65e5e991
    • A
      autofs: fix a leak in autofs_expire_indirect() · d4bc855a
      Al Viro 提交于
      [ Upstream commit 03ad0d703df75c43f78bd72e16124b5b94a95188 ]
      
      if the second call of should_expire() in there ends up
      grabbing and returning a new reference to dentry, we need
      to drop it before continuing.
      Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
      Signed-off-by: NSasha Levin <sashal@kernel.org>
      d4bc855a
    • C
      serial: ifx6x60: add missed pm_runtime_disable · c44d21f8
      Chuhong Yuan 提交于
      commit 50b2b571c5f3df721fc81bf9a12c521dfbe019ba upstream.
      
      The driver forgets to call pm_runtime_disable in remove.
      Add the missed calls to fix it.
      Signed-off-by: NChuhong Yuan <hslester96@gmail.com>
      Cc: stable <stable@vger.kernel.org>
      Link: https://lore.kernel.org/r/20191118024833.21587-1-hslester96@gmail.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c44d21f8
    • J
      serial: serial_core: Perform NULL checks for break_ctl ops · bd95aea9
      Jiangfeng Xiao 提交于
      commit 7d73170e1c282576419f8b50a771f1fcd2b81a94 upstream.
      
      Doing fuzz test on sbsa uart device, causes a kernel crash
      due to NULL pointer dereference:
      
      ------------[ cut here ]------------
      Unable to handle kernel paging request at virtual address fffffffffffffffc
      pgd = ffffffe331723000
      [fffffffffffffffc] *pgd=0000002333595003, *pud=0000002333595003, *pmd=00000
      Internal error: Oops: 96000005 [#1] PREEMPT SMP
      Modules linked in: ping(O) jffs2 rtos_snapshot(O) pramdisk(O) hisi_sfc(O)
      Drv_Nandc_K(O) Drv_SysCtl_K(O) Drv_SysClk_K(O) bsp_reg(O) hns3(O)
      hns3_uio_enet(O) hclgevf(O) hclge(O) hnae3(O) mdio_factory(O)
      mdio_registry(O) mdio_dev(O) mdio(O) hns3_info(O) rtos_kbox_panic(O)
      uart_suspend(O) rsm(O) stp llc tunnel4 xt_tcpudp ipt_REJECT nf_reject_ipv4
      iptable_filter ip_tables x_tables sd_mod xhci_plat_hcd xhci_pci xhci_hcd
      usbmon usbhid usb_storage ohci_platform ohci_pci ohci_hcd hid_generic hid
      ehci_platform ehci_pci ehci_hcd vfat fat usbcore usb_common scsi_mod
      yaffs2multi(O) ext4 jbd2 ext2 mbcache ofpart i2c_dev i2c_core uio ubi nand
      nand_ecc nand_ids cfi_cmdset_0002 cfi_cmdset_0001 cfi_probe gen_probe
      cmdlinepart chipreg mtdblock mtd_blkdevs mtd nfsd auth_rpcgss oid_registry
      nfsv3 nfs nfs_acl lockd sunrpc grace autofs4
      CPU: 2 PID: 2385 Comm: tty_fuzz_test Tainted: G           O    4.4.193 #1
      task: ffffffe32b23f110 task.stack: ffffffe32bda4000
      PC is at uart_break_ctl+0x44/0x84
      LR is at uart_break_ctl+0x34/0x84
      pc : [<ffffff8393196098>] lr : [<ffffff8393196088>] pstate: 80000005
      sp : ffffffe32bda7cc0
      x29: ffffffe32bda7cc0 x28: ffffffe32b23f110
      x27: ffffff8393402000 x26: 0000000000000000
      x25: ffffffe32b233f40 x24: ffffffc07a8ec680
      x23: 0000000000005425 x22: 00000000ffffffff
      x21: ffffffe33ed73c98 x20: 0000000000000000
      x19: ffffffe33ed94168 x18: 0000000000000004
      x17: 0000007f92ae9d30 x16: ffffff8392fa6064
      x15: 0000000000000010 x14: 0000000000000000
      x13: 0000000000000000 x12: 0000000000000000
      x11: 0000000000000020 x10: 0000007ffdac1708
      x9 : 0000000000000078 x8 : 000000000000001d
      x7 : 0000000052a64887 x6 : ffffffe32bda7e08
      x5 : ffffffe32b23c000 x4 : 0000005fbc5b0000
      x3 : ffffff83938d5018 x2 : 0000000000000080
      x1 : ffffffe32b23c040 x0 : ffffff83934428f8
      virtual start addr offset is 38ac00000
      module base offset is 2cd4cf1000
      linear region base offset is : 0
      Process tty_fuzz_test (pid: 2385, stack limit = 0xffffffe32bda4000)
      Stack: (0xffffffe32bda7cc0 to 0xffffffe32bda8000)
      7cc0: ffffffe32bda7cf0 ffffff8393177718 ffffffc07a8ec680 ffffff8393196054
      7ce0: 000000001739f2e0 0000007ffdac1978 ffffffe32bda7d20 ffffff8393179a1c
      7d00: 0000000000000000 ffffff8393c0a000 ffffffc07a8ec680 cb88537fdc8ba600
      7d20: ffffffe32bda7df0 ffffff8392fa5a40 ffffff8393c0a000 0000000000005425
      7d40: 0000007ffdac1978 ffffffe32b233f40 ffffff8393178dcc 0000000000000003
      7d60: 000000000000011d 000000000000001d ffffffe32b23f110 000000000000029e
      7d80: ffffffe34fe8d5d0 0000000000000000 ffffffe32bda7e14 cb88537fdc8ba600
      7da0: ffffffe32bda7e30 ffffff8393042cfc ffffff8393c41720 ffffff8393c46410
      7dc0: ffffff839304fa68 ffffffe32b233f40 0000000000005425 0000007ffdac1978
      7de0: 000000000000011d cb88537fdc8ba600 ffffffe32bda7e70 ffffff8392fa60cc
      7e00: 0000000000000000 ffffffe32b233f40 ffffffe32b233f40 0000000000000003
      7e20: 0000000000005425 0000007ffdac1978 ffffffe32bda7e70 ffffff8392fa60b0
      7e40: 0000000000000280 ffffffe32b233f40 ffffffe32b233f40 0000000000000003
      7e60: 0000000000005425 cb88537fdc8ba600 0000000000000000 ffffff8392e02e78
      7e80: 0000000000000280 0000005fbc5b0000 ffffffffffffffff 0000007f92ae9d3c
      7ea0: 0000000060000000 0000000000000015 0000000000000003 0000000000005425
      7ec0: 0000007ffdac1978 0000000000000000 00000000a54c910e 0000007f92b95014
      7ee0: 0000007f92b95090 0000000052a64887 000000000000001d 0000000000000078
      7f00: 0000007ffdac1708 0000000000000020 0000000000000000 0000000000000000
      7f20: 0000000000000000 0000000000000010 000000556acf0090 0000007f92ae9d30
      7f40: 0000000000000004 000000556acdef10 0000000000000000 000000556acdebd0
      7f60: 0000000000000000 0000000000000000 0000000000000000 0000000000000000
      7f80: 0000000000000000 0000000000000000 0000000000000000 0000007ffdac1840
      7fa0: 000000556acdedcc 0000007ffdac1840 0000007f92ae9d3c 0000000060000000
      7fc0: 0000000000000000 0000000000000000 0000000000000003 000000000000001d
      7fe0: 0000000000000000 0000000000000000 0000000000000000 0000000000000000
      Call trace:
      Exception stack(0xffffffe32bda7ab0 to 0xffffffe32bda7bf0)
      7aa0:                                   0000000000001000 0000007fffffffff
      7ac0: ffffffe32bda7cc0 ffffff8393196098 0000000080000005 0000000000000025
      7ae0: ffffffe32b233f40 ffffff83930d777c ffffffe32bda7b30 ffffff83930d777c
      7b00: ffffffe32bda7be0 ffffff83938d5000 ffffffe32bda7be0 ffffffe32bda7c20
      7b20: ffffffe32bda7b60 ffffff83930d777c ffffffe32bda7c10 ffffff83938d5000
      7b40: ffffffe32bda7c10 ffffffe32bda7c50 ffffff8393c0a000 ffffffe32b23f110
      7b60: ffffffe32bda7b70 ffffff8392e09df4 ffffffe32bda7bb0 cb88537fdc8ba600
      7b80: ffffff83934428f8 ffffffe32b23c040 0000000000000080 ffffff83938d5018
      7ba0: 0000005fbc5b0000 ffffffe32b23c000 ffffffe32bda7e08 0000000052a64887
      7bc0: 000000000000001d 0000000000000078 0000007ffdac1708 0000000000000020
      7be0: 0000000000000000 0000000000000000
      [<ffffff8393196098>] uart_break_ctl+0x44/0x84
      [<ffffff8393177718>] send_break+0xa0/0x114
      [<ffffff8393179a1c>] tty_ioctl+0xc50/0xe84
      [<ffffff8392fa5a40>] do_vfs_ioctl+0xc4/0x6e8
      [<ffffff8392fa60cc>] SyS_ioctl+0x68/0x9c
      [<ffffff8392e02e78>] __sys_trace_return+0x0/0x4
      Code: b9410ea0 34000160 f9408aa0 f9402814 (b85fc280)
      ---[ end trace 8606094f1960c5e0 ]---
      Kernel panic - not syncing: Fatal exception
      
      Fix this problem by adding NULL checks prior to calling break_ctl ops.
      Signed-off-by: NJiangfeng Xiao <xiaojiangfeng@huawei.com>
      Cc: stable <stable@vger.kernel.org>
      Link: https://lore.kernel.org/r/1574263133-28259-1-git-send-email-xiaojiangfeng@huawei.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      bd95aea9
    • V
      serial: pl011: Fix DMA ->flush_buffer() · 4fca5202
      Vincent Whitchurch 提交于
      commit f6a196477184b99a31d16366a8e826558aa11f6d upstream.
      
      PL011's ->flush_buffer() implementation releases and reacquires the port
      lock.  Due to a race condition here, data can end up being added to the
      circular buffer but neither being discarded nor being sent out.  This
      leads to, for example, tcdrain(2) waiting indefinitely.
      
      Process A                       Process B
      
      uart_flush_buffer()
       - acquire lock
       - circ_clear
       - pl011_flush_buffer()
       -- release lock
       -- dmaengine_terminate_all()
      
                                      uart_write()
                                      - acquire lock
                                      - add chars to circ buffer
                                      - start_tx()
                                      -- start DMA
                                      - release lock
      
       -- acquire lock
       -- turn off DMA
       -- release lock
      
                                      // Data in circ buffer but DMA is off
      
      According to the comment in the code, the releasing of the lock around
      dmaengine_terminate_all() is to avoid a deadlock with the DMA engine
      callback.  However, since the time this code was written, the DMA engine
      API documentation seems to have been clarified to say that
      dmaengine_terminate_all() (in the identically implemented but
      differently named dmaengine_terminate_async() variant) does not wait for
      any running complete callback to be completed and can even be called
      from a complete callback.  So there is no possibility of deadlock if the
      DMA engine driver implements this API correctly.
      
      So we should be able to just remove this release and reacquire of the
      lock to prevent the aforementioned race condition.
      Signed-off-by: NVincent Whitchurch <vincent.whitchurch@axis.com>
      Cc: stable <stable@vger.kernel.org>
      Link: https://lore.kernel.org/r/20191118092547.32135-1-vincent.whitchurch@axis.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      4fca5202
    • J
      tty: serial: msm_serial: Fix flow control · 4f729489
      Jeffrey Hugo 提交于
      commit b027ce258369cbfa88401a691c23dad01deb9f9b upstream.
      
      hci_qca interfaces to the wcn3990 via a uart_dm on the msm8998 mtp and
      Lenovo Miix 630 laptop.  As part of initializing the wcn3990, hci_qca
      disables flow, configures the uart baudrate, and then reenables flow - at
      which point an event is expected to be received over the uart from the
      wcn3990.  It is observed that this event comes after the baudrate change
      but before hci_qca re-enables flow. This is unexpected, and is a result of
      msm_reset() being broken.
      
      According to the uart_dm hardware documentation, it is recommended that
      automatic hardware flow control be enabled by setting RX_RDY_CTL.  Auto
      hw flow control will manage RFR based on the configured watermark.  When
      there is space to receive data, the hw will assert RFR.  When the watermark
      is hit, the hw will de-assert RFR.
      
      The hardware documentation indicates that RFR can me manually managed via
      CR when RX_RDY_CTL is not set.  SET_RFR asserts RFR, and RESET_RFR
      de-asserts RFR.
      
      msm_reset() is broken because after resetting the hardware, it
      unconditionally asserts RFR via SET_RFR.  This enables flow regardless of
      the current configuration, and would undo a previous flow disable
      operation.  It should instead de-assert RFR via RESET_RFR to block flow
      until the hardware is reconfigured.  msm_serial should rely on the client
      to specify that flow should be enabled, either via mctrl() or the termios
      structure, and only assert RFR in response to those triggers.
      
      Fixes: 04896a77 ("msm_serial: serial driver for MSM7K onboard serial peripheral.")
      Signed-off-by: NJeffrey Hugo <jeffrey.l.hugo@gmail.com>
      Reviewed-by: NBjorn Andersson <bjorn.andersson@linaro.org>
      Cc: stable <stable@vger.kernel.org>
      Reviewed-by: NAndy Gross <agross@kernel.org>
      Link: https://lore.kernel.org/r/20191021154616.25457-1-jeffrey.l.hugo@gmail.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      4f729489
    • P
      tty: serial: fsl_lpuart: use the sg count from dma_map_sg · 8f7600e2
      Peng Fan 提交于
      commit 487ee861de176090b055eba5b252b56a3b9973d6 upstream.
      
      The dmaengine_prep_slave_sg needs to use sg count returned
      by dma_map_sg, not use sport->dma_tx_nents, because the return
      value of dma_map_sg is not always same with "nents".
      
      When enabling iommu for lpuart + edma, iommu framework may concatenate
      two sgs into one.
      
      Fixes: 6250cc30 ("tty: serial: fsl_lpuart: Use scatter/gather DMA for Tx")
      Cc: <stable@vger.kernel.org>
      Signed-off-by: NPeng Fan <peng.fan@nxp.com>
      Link: https://lore.kernel.org/r/1572932977-17866-1-git-send-email-peng.fan@nxp.comSigned-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      8f7600e2
    • M
      usb: gadget: u_serial: add missing port entry locking · c5a309dc
      Michał Mirosław 提交于
      commit daf82bd24e308c5a83758047aff1bd81edda4f11 upstream.
      
      gserial_alloc_line() misses locking (for a release barrier) while
      resetting port entry on TTY allocation failure. Fix this.
      
      Cc: stable@vger.kernel.org
      Signed-off-by: NMichał Mirosław <mirq-linux@rere.qmqm.pl>
      Reviewed-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      Tested-by: NLadislav Michl <ladis@linux-mips.org>
      Signed-off-by: NFelipe Balbi <felipe.balbi@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c5a309dc