Skip to content

Commit bc09bee

Browse files
committed
Merge 4.19.156 into android-4.19-stable
Changes in 4.19.156 drm/i915: Break up error capture compression loops with cond_resched() tipc: fix use-after-free in tipc_bcast_get_mode ptrace: fix task_join_group_stop() for the case when current is traced cadence: force nonlinear buffers to be cloned chelsio/chtls: fix memory leaks caused by a race chelsio/chtls: fix always leaking ctrl_skb gianfar: Replace skb_realloc_headroom with skb_cow_head for PTP gianfar: Account for Tx PTP timestamp in the skb headroom net: usb: qmi_wwan: add Telit LE910Cx 0x1230 composition sctp: Fix COMM_LOST/CANT_STR_ASSOC err reporting on big-endian platforms sfp: Fix error handing in sfp_probe() blktrace: fix debugfs use after free btrfs: extent_io: Kill the forward declaration of flush_write_bio btrfs: extent_io: Move the BUG_ON() in flush_write_bio() one level up Revert "btrfs: flush write bio if we loop in extent_write_cache_pages" btrfs: flush write bio if we loop in extent_write_cache_pages btrfs: extent_io: Handle errors better in extent_write_full_page() btrfs: extent_io: Handle errors better in btree_write_cache_pages() btrfs: extent_io: add proper error handling to lock_extent_buffer_for_io() Btrfs: fix unwritten extent buffers and hangs on future writeback attempts btrfs: Don't submit any btree write bio if the fs has errors btrfs: Move btrfs_check_chunk_valid() to tree-check.[ch] and export it btrfs: tree-checker: Make chunk item checker messages more readable btrfs: tree-checker: Make btrfs_check_chunk_valid() return EUCLEAN instead of EIO btrfs: tree-checker: Check chunk item at tree block read time btrfs: tree-checker: Verify dev item btrfs: tree-checker: Fix wrong check on max devid btrfs: tree-checker: Enhance chunk checker to validate chunk profile btrfs: tree-checker: Verify inode item btrfs: tree-checker: fix the error message for transid error Fonts: Replace discarded const qualifier ALSA: usb-audio: Add implicit feedback quirk for Zoom UAC-2 ALSA: usb-audio: add usb vendor id as DSD-capable for Khadas devices ALSA: usb-audio: Add implicit feedback quirk for Qu-16 ALSA: usb-audio: Add implicit feedback quirk for MODX mm: mempolicy: fix potential pte_unmap_unlock pte error lib/crc32test: remove extra local_irq_disable/enable kthread_worker: prevent queuing delayed work from timer_fn when it is being canceled mm: always have io_remap_pfn_range() set pgprot_decrypted() gfs2: Wake up when sd_glock_disposal becomes zero ring-buffer: Fix recursion protection transitions between interrupt context ftrace: Fix recursion check for NMI test ftrace: Handle tracing when switching between context tracing: Fix out of bounds write in get_trace_buf futex: Handle transient "ownerless" rtmutex state correctly ARM: dts: sun4i-a10: fix cpu_alert temperature x86/kexec: Use up-to-dated screen_info copy to fill boot params of: Fix reserved-memory overlap detection blk-cgroup: Fix memleak on error path blk-cgroup: Pre-allocate tree node on blkg_conf_prep scsi: core: Don't start concurrent async scan on same host vsock: use ns_capable_noaudit() on socket create drm/vc4: drv: Add error handding for bind ACPI: NFIT: Fix comparison to '-ENXIO' vt: Disable KD_FONT_OP_COPY fork: fix copy_process(CLONE_PARENT) race with the exiting ->real_parent serial: 8250_mtk: Fix uart_get_baud_rate warning serial: txx9: add missing platform_driver_unregister() on error in serial_txx9_init USB: serial: cyberjack: fix write-URB completion race USB: serial: option: add Quectel EC200T module support USB: serial: option: add LE910Cx compositions 0x1203, 0x1230, 0x1231 USB: serial: option: add Telit FN980 composition 0x1055 USB: Add NO_LPM quirk for Kingston flash drive usb: mtu3: fix panic in mtu3_gadget_stop() ARC: stack unwinding: avoid indefinite looping Revert "ARC: entry: fix potential EFA clobber when TIF_SYSCALL_TRACE" PM: runtime: Resume the device earlier in __device_release_driver() perf/core: Fix a memory leak in perf_event_parse_addr_filter() tools: perf: Fix build error in v4.19.y net: dsa: read mac address from DT for slave device arm64: dts: marvell: espressobin: Add ethernet switch aliases Linux 4.19.156 Signed-off-by: Greg Kroah-Hartman <[email protected]> Change-Id: I87af8871465f54de0332fa74bc1f342b7fe99061
2 parents fa19989 + 53fff24 commit bc09bee

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

67 files changed

+807
-297
lines changed

Makefile

+1-1
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
# SPDX-License-Identifier: GPL-2.0
22
VERSION = 4
33
PATCHLEVEL = 19
4-
SUBLEVEL = 155
4+
SUBLEVEL = 156
55
EXTRAVERSION =
66
NAME = "People's Front"
77

arch/arc/kernel/entry.S

+11-5
Original file line numberDiff line numberDiff line change
@@ -156,6 +156,7 @@ END(EV_Extension)
156156
tracesys:
157157
; save EFA in case tracer wants the PC of traced task
158158
; using ERET won't work since next-PC has already committed
159+
lr r12, [efa]
159160
GET_CURR_TASK_FIELD_PTR TASK_THREAD, r11
160161
st r12, [r11, THREAD_FAULT_ADDR] ; thread.fault_address
161162

@@ -198,9 +199,15 @@ tracesys_exit:
198199
; Breakpoint TRAP
199200
; ---------------------------------------------
200201
trap_with_param:
201-
mov r0, r12 ; EFA in case ptracer/gdb wants stop_pc
202+
203+
; stop_pc info by gdb needs this info
204+
lr r0, [efa]
202205
mov r1, sp
203206

207+
; Now that we have read EFA, it is safe to do "fake" rtie
208+
; and get out of CPU exception mode
209+
FAKE_RET_FROM_EXCPN
210+
204211
; Save callee regs in case gdb wants to have a look
205212
; SP will grow up by size of CALLEE Reg-File
206213
; NOTE: clobbers r12
@@ -227,17 +234,16 @@ ENTRY(EV_Trap)
227234

228235
EXCEPTION_PROLOGUE
229236

230-
lr r12, [efa]
231-
232-
FAKE_RET_FROM_EXCPN
233-
234237
;============ TRAP 1 :breakpoints
235238
; Check ECR for trap with arg (PROLOGUE ensures r9 has ECR)
236239
bmsk.f 0, r9, 7
237240
bnz trap_with_param
238241

239242
;============ TRAP (no param): syscall top level
240243

244+
; First return from Exception to pure K mode (Exception/IRQs renabled)
245+
FAKE_RET_FROM_EXCPN
246+
241247
; If syscall tracing ongoing, invoke pre-post-hooks
242248
GET_CURR_THR_INFO_FLAGS r10
243249
btst r10, TIF_SYSCALL_TRACE

arch/arc/kernel/stacktrace.c

+6-1
Original file line numberDiff line numberDiff line change
@@ -115,7 +115,7 @@ arc_unwind_core(struct task_struct *tsk, struct pt_regs *regs,
115115
int (*consumer_fn) (unsigned int, void *), void *arg)
116116
{
117117
#ifdef CONFIG_ARC_DW2_UNWIND
118-
int ret = 0;
118+
int ret = 0, cnt = 0;
119119
unsigned int address;
120120
struct unwind_frame_info frame_info;
121121

@@ -135,6 +135,11 @@ arc_unwind_core(struct task_struct *tsk, struct pt_regs *regs,
135135
break;
136136

137137
frame_info.regs.r63 = frame_info.regs.r31;
138+
139+
if (cnt++ > 128) {
140+
printk("unwinder looping too long, aborting !\n");
141+
return 0;
142+
}
138143
}
139144

140145
return address; /* return the last address it saw */

arch/arm/boot/dts/sun4i-a10.dtsi

+1-1
Original file line numberDiff line numberDiff line change
@@ -143,7 +143,7 @@
143143
trips {
144144
cpu_alert0: cpu-alert0 {
145145
/* milliCelsius */
146-
temperature = <850000>;
146+
temperature = <85000>;
147147
hysteresis = <2000>;
148148
type = "passive";
149149
};

arch/arm64/boot/dts/marvell/armada-3720-espressobin.dts

+8-4
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,10 @@
2121

2222
aliases {
2323
ethernet0 = &eth0;
24+
/* for dsa slave device */
25+
ethernet1 = &switch0port1;
26+
ethernet2 = &switch0port2;
27+
ethernet3 = &switch0port3;
2428
serial0 = &uart0;
2529
serial1 = &uart1;
2630
};
@@ -136,25 +140,25 @@
136140
#address-cells = <1>;
137141
#size-cells = <0>;
138142

139-
port@0 {
143+
switch0port0: port@0 {
140144
reg = <0>;
141145
label = "cpu";
142146
ethernet = <&eth0>;
143147
};
144148

145-
port@1 {
149+
switch0port1: port@1 {
146150
reg = <1>;
147151
label = "wan";
148152
phy-handle = <&switch0phy0>;
149153
};
150154

151-
port@2 {
155+
switch0port2: port@2 {
152156
reg = <2>;
153157
label = "lan0";
154158
phy-handle = <&switch0phy1>;
155159
};
156160

157-
port@3 {
161+
switch0port3: port@3 {
158162
reg = <3>;
159163
label = "lan1";
160164
phy-handle = <&switch0phy2>;

arch/x86/kernel/kexec-bzimage64.c

+1-2
Original file line numberDiff line numberDiff line change
@@ -211,8 +211,7 @@ setup_boot_parameters(struct kimage *image, struct boot_params *params,
211211
params->hdr.hardware_subarch = boot_params.hdr.hardware_subarch;
212212

213213
/* Copying screen_info will do? */
214-
memcpy(&params->screen_info, &boot_params.screen_info,
215-
sizeof(struct screen_info));
214+
memcpy(&params->screen_info, &screen_info, sizeof(struct screen_info));
216215

217216
/* Fill in memsize later */
218217
params->screen_info.ext_mem_k = 0;

block/blk-cgroup.c

+13-2
Original file line numberDiff line numberDiff line change
@@ -876,13 +876,20 @@ int blkg_conf_prep(struct blkcg *blkcg, const struct blkcg_policy *pol,
876876
goto fail;
877877
}
878878

879+
if (radix_tree_preload(GFP_KERNEL)) {
880+
blkg_free(new_blkg);
881+
ret = -ENOMEM;
882+
goto fail;
883+
}
884+
879885
rcu_read_lock();
880886
spin_lock_irq(q->queue_lock);
881887

882888
blkg = blkg_lookup_check(pos, pol, q);
883889
if (IS_ERR(blkg)) {
884890
ret = PTR_ERR(blkg);
885-
goto fail_unlock;
891+
blkg_free(new_blkg);
892+
goto fail_preloaded;
886893
}
887894

888895
if (blkg) {
@@ -891,10 +898,12 @@ int blkg_conf_prep(struct blkcg *blkcg, const struct blkcg_policy *pol,
891898
blkg = blkg_create(pos, q, new_blkg);
892899
if (unlikely(IS_ERR(blkg))) {
893900
ret = PTR_ERR(blkg);
894-
goto fail_unlock;
901+
goto fail_preloaded;
895902
}
896903
}
897904

905+
radix_tree_preload_end();
906+
898907
if (pos == blkcg)
899908
goto success;
900909
}
@@ -904,6 +913,8 @@ int blkg_conf_prep(struct blkcg *blkcg, const struct blkcg_policy *pol,
904913
ctx->body = body;
905914
return 0;
906915

916+
fail_preloaded:
917+
radix_tree_preload_end();
907918
fail_unlock:
908919
spin_unlock_irq(q->queue_lock);
909920
rcu_read_unlock();

drivers/acpi/nfit/core.c

+1-1
Original file line numberDiff line numberDiff line change
@@ -1535,7 +1535,7 @@ static ssize_t format1_show(struct device *dev,
15351535
le16_to_cpu(nfit_dcr->dcr->code));
15361536
break;
15371537
}
1538-
if (rc != ENXIO)
1538+
if (rc != -ENXIO)
15391539
break;
15401540
}
15411541
mutex_unlock(&acpi_desc->init_mutex);

drivers/base/dd.c

+5-2
Original file line numberDiff line numberDiff line change
@@ -936,6 +936,8 @@ static void __device_release_driver(struct device *dev, struct device *parent)
936936

937937
drv = dev->driver;
938938
if (drv) {
939+
pm_runtime_get_sync(dev);
940+
939941
while (device_links_busy(dev)) {
940942
device_unlock(dev);
941943
if (parent && dev->bus->need_parent_lock)
@@ -951,11 +953,12 @@ static void __device_release_driver(struct device *dev, struct device *parent)
951953
* have released the driver successfully while this one
952954
* was waiting, so check for that.
953955
*/
954-
if (dev->driver != drv)
956+
if (dev->driver != drv) {
957+
pm_runtime_put(dev);
955958
return;
959+
}
956960
}
957961

958-
pm_runtime_get_sync(dev);
959962
pm_runtime_clean_up_links(dev);
960963

961964
driver_sysfs_remove(dev);

drivers/crypto/chelsio/chtls/chtls_cm.c

+1-1
Original file line numberDiff line numberDiff line change
@@ -175,7 +175,7 @@ static struct sk_buff *alloc_ctrl_skb(struct sk_buff *skb, int len)
175175
{
176176
if (likely(skb && !skb_shared(skb) && !skb_cloned(skb))) {
177177
__skb_trim(skb, 0);
178-
refcount_add(2, &skb->users);
178+
refcount_inc(&skb->users);
179179
} else {
180180
skb = alloc_skb(len, GFP_KERNEL | __GFP_NOFAIL);
181181
}

drivers/crypto/chelsio/chtls/chtls_hw.c

+3
Original file line numberDiff line numberDiff line change
@@ -368,6 +368,9 @@ int chtls_setkey(struct chtls_sock *csk, u32 keylen, u32 optname)
368368
if (ret)
369369
goto out_notcb;
370370

371+
if (unlikely(csk_flag(sk, CSK_ABORT_SHUTDOWN)))
372+
goto out_notcb;
373+
371374
set_wr_txq(skb, CPL_PRIORITY_DATA, csk->tlshws.txqid);
372375
csk->wr_credits -= DIV_ROUND_UP(len, 16);
373376
csk->wr_unacked += DIV_ROUND_UP(len, 16);

drivers/gpu/drm/i915/i915_gpu_error.c

+3
Original file line numberDiff line numberDiff line change
@@ -268,6 +268,8 @@ static int compress_page(struct compress *c,
268268

269269
if (zlib_deflate(zstream, Z_NO_FLUSH) != Z_OK)
270270
return -EIO;
271+
272+
cond_resched();
271273
} while (zstream->avail_in);
272274

273275
/* Fallback to uncompressed if we increase size? */
@@ -347,6 +349,7 @@ static int compress_page(struct compress *c,
347349
if (!i915_memcpy_from_wc(ptr, src, PAGE_SIZE))
348350
memcpy(ptr, src, PAGE_SIZE);
349351
dst->pages[dst->page_count++] = ptr;
352+
cond_resched();
350353

351354
return 0;
352355
}

drivers/gpu/drm/vc4/vc4_drv.c

+1
Original file line numberDiff line numberDiff line change
@@ -312,6 +312,7 @@ static int vc4_drm_bind(struct device *dev)
312312
component_unbind_all(dev, drm);
313313
gem_destroy:
314314
vc4_gem_destroy(drm);
315+
drm_mode_config_cleanup(drm);
315316
vc4_bo_cache_destroy(drm);
316317
dev_put:
317318
drm_dev_put(drm);

drivers/net/ethernet/cadence/macb_main.c

+2-1
Original file line numberDiff line numberDiff line change
@@ -1704,7 +1704,8 @@ static inline int macb_clear_csum(struct sk_buff *skb)
17041704

17051705
static int macb_pad_and_fcs(struct sk_buff **skb, struct net_device *ndev)
17061706
{
1707-
bool cloned = skb_cloned(*skb) || skb_header_cloned(*skb);
1707+
bool cloned = skb_cloned(*skb) || skb_header_cloned(*skb) ||
1708+
skb_is_nonlinear(*skb);
17081709
int padlen = ETH_ZLEN - (*skb)->len;
17091710
int headroom = skb_headroom(*skb);
17101711
int tailroom = skb_tailroom(*skb);

drivers/net/ethernet/freescale/gianfar.c

+3-11
Original file line numberDiff line numberDiff line change
@@ -1388,7 +1388,7 @@ static int gfar_probe(struct platform_device *ofdev)
13881388

13891389
if (dev->features & NETIF_F_IP_CSUM ||
13901390
priv->device_flags & FSL_GIANFAR_DEV_HAS_TIMER)
1391-
dev->needed_headroom = GMAC_FCB_LEN;
1391+
dev->needed_headroom = GMAC_FCB_LEN + GMAC_TXPAL_LEN;
13921392

13931393
/* Initializing some of the rx/tx queue level parameters */
13941394
for (i = 0; i < priv->num_tx_queues; i++) {
@@ -2370,20 +2370,12 @@ static netdev_tx_t gfar_start_xmit(struct sk_buff *skb, struct net_device *dev)
23702370
fcb_len = GMAC_FCB_LEN + GMAC_TXPAL_LEN;
23712371

23722372
/* make space for additional header when fcb is needed */
2373-
if (fcb_len && unlikely(skb_headroom(skb) < fcb_len)) {
2374-
struct sk_buff *skb_new;
2375-
2376-
skb_new = skb_realloc_headroom(skb, fcb_len);
2377-
if (!skb_new) {
2373+
if (fcb_len) {
2374+
if (unlikely(skb_cow_head(skb, fcb_len))) {
23782375
dev->stats.tx_errors++;
23792376
dev_kfree_skb_any(skb);
23802377
return NETDEV_TX_OK;
23812378
}
2382-
2383-
if (skb->sk)
2384-
skb_set_owner_w(skb_new, skb->sk);
2385-
dev_consume_skb_any(skb);
2386-
skb = skb_new;
23872379
}
23882380

23892381
/* total number of fragments in the SKB */

drivers/net/phy/sfp.c

+2-1
Original file line numberDiff line numberDiff line change
@@ -1886,7 +1886,8 @@ static int sfp_probe(struct platform_device *pdev)
18861886
continue;
18871887

18881888
irq = gpiod_to_irq(sfp->gpio[i]);
1889-
if (!irq) {
1889+
if (irq < 0) {
1890+
irq = 0;
18901891
poll = true;
18911892
continue;
18921893
}

drivers/net/usb/qmi_wwan.c

+1
Original file line numberDiff line numberDiff line change
@@ -1268,6 +1268,7 @@ static const struct usb_device_id products[] = {
12681268
{QMI_FIXED_INTF(0x1bc7, 0x1101, 3)}, /* Telit ME910 dual modem */
12691269
{QMI_FIXED_INTF(0x1bc7, 0x1200, 5)}, /* Telit LE920 */
12701270
{QMI_QUIRK_SET_DTR(0x1bc7, 0x1201, 2)}, /* Telit LE920, LE920A4 */
1271+
{QMI_QUIRK_SET_DTR(0x1bc7, 0x1230, 2)}, /* Telit LE910Cx */
12711272
{QMI_QUIRK_SET_DTR(0x1bc7, 0x1260, 2)}, /* Telit LE910Cx */
12721273
{QMI_QUIRK_SET_DTR(0x1bc7, 0x1261, 2)}, /* Telit LE910Cx */
12731274
{QMI_QUIRK_SET_DTR(0x1bc7, 0x1900, 1)}, /* Telit LN940 series */

drivers/of/of_reserved_mem.c

+11-2
Original file line numberDiff line numberDiff line change
@@ -221,6 +221,16 @@ static int __init __rmem_cmp(const void *a, const void *b)
221221
if (ra->base > rb->base)
222222
return 1;
223223

224+
/*
225+
* Put the dynamic allocations (address == 0, size == 0) before static
226+
* allocations at address 0x0 so that overlap detection works
227+
* correctly.
228+
*/
229+
if (ra->size < rb->size)
230+
return -1;
231+
if (ra->size > rb->size)
232+
return 1;
233+
224234
return 0;
225235
}
226236

@@ -238,8 +248,7 @@ static void __init __rmem_check_for_overlap(void)
238248

239249
this = &reserved_mem[i];
240250
next = &reserved_mem[i + 1];
241-
if (!(this->base && next->base))
242-
continue;
251+
243252
if (this->base + this->size > next->base) {
244253
phys_addr_t this_end, next_end;
245254

drivers/scsi/scsi_scan.c

+4-3
Original file line numberDiff line numberDiff line change
@@ -1722,15 +1722,16 @@ static void scsi_sysfs_add_devices(struct Scsi_Host *shost)
17221722
*/
17231723
static struct async_scan_data *scsi_prep_async_scan(struct Scsi_Host *shost)
17241724
{
1725-
struct async_scan_data *data;
1725+
struct async_scan_data *data = NULL;
17261726
unsigned long flags;
17271727

17281728
if (strncmp(scsi_scan_type, "sync", 4) == 0)
17291729
return NULL;
17301730

1731+
mutex_lock(&shost->scan_mutex);
17311732
if (shost->async_scan) {
17321733
shost_printk(KERN_DEBUG, shost, "%s called twice\n", __func__);
1733-
return NULL;
1734+
goto err;
17341735
}
17351736

17361737
data = kmalloc(sizeof(*data), GFP_KERNEL);
@@ -1741,7 +1742,6 @@ static struct async_scan_data *scsi_prep_async_scan(struct Scsi_Host *shost)
17411742
goto err;
17421743
init_completion(&data->prev_finished);
17431744

1744-
mutex_lock(&shost->scan_mutex);
17451745
spin_lock_irqsave(shost->host_lock, flags);
17461746
shost->async_scan = 1;
17471747
spin_unlock_irqrestore(shost->host_lock, flags);
@@ -1756,6 +1756,7 @@ static struct async_scan_data *scsi_prep_async_scan(struct Scsi_Host *shost)
17561756
return data;
17571757

17581758
err:
1759+
mutex_unlock(&shost->scan_mutex);
17591760
kfree(data);
17601761
return NULL;
17611762
}

drivers/tty/serial/8250/8250_mtk.c

+1-1
Original file line numberDiff line numberDiff line change
@@ -47,7 +47,7 @@ mtk8250_set_termios(struct uart_port *port, struct ktermios *termios,
4747
*/
4848
baud = tty_termios_baud_rate(termios);
4949

50-
serial8250_do_set_termios(port, termios, old);
50+
serial8250_do_set_termios(port, termios, NULL);
5151

5252
tty_termios_encode_baud_rate(termios, baud, baud);
5353

drivers/tty/serial/serial_txx9.c

+3
Original file line numberDiff line numberDiff line change
@@ -1284,6 +1284,9 @@ static int __init serial_txx9_init(void)
12841284

12851285
#ifdef ENABLE_SERIAL_TXX9_PCI
12861286
ret = pci_register_driver(&serial_txx9_pci_driver);
1287+
if (ret) {
1288+
platform_driver_unregister(&serial_txx9_plat_driver);
1289+
}
12871290
#endif
12881291
if (ret == 0)
12891292
goto out;

0 commit comments

Comments
 (0)