Merge 4.14.147 into android-4.14-q
authorGreg Kroah-Hartman <gregkh@google.com>
Sun, 6 Oct 2019 10:38:20 +0000 (12:38 +0200)
committerGreg Kroah-Hartman <gregkh@google.com>
Sun, 6 Oct 2019 10:38:20 +0000 (12:38 +0200)
Changes in 4.14.147
Revert "Bluetooth: validate BLE connection interval updates"
powerpc/xive: Fix bogus error code returned by OPAL
objtool: Query pkg-config for libelf location
IB/core: Add an unbound WQ type to the new CQ API
HID: prodikeys: Fix general protection fault during probe
HID: sony: Fix memory corruption issue on cleanup.
HID: logitech: Fix general protection fault caused by Logitech driver
HID: hidraw: Fix invalid read in hidraw_ioctl
mtd: cfi_cmdset_0002: Use chip_good() to retry in do_write_oneword()
crypto: talitos - fix missing break in switch statement
iwlwifi: mvm: send BCAST management frames to the right station
media: tvp5150: fix switch exit in set control handler
ASoC: fsl: Fix of-node refcount unbalance in fsl_ssi_probe_from_dt()
arm64: kpti: Whitelist Cortex-A CPUs that don't implement the CSV3 field
ALSA: hda - Add laptop imic fixup for ASUS M9V laptop
ALSA: hda - Apply AMD controller workaround for Raven platform
objtool: Clobber user CFLAGS variable
pinctrl: sprd: Use define directive for sprd_pinconf_params values
power: supply: sysfs: ratelimit property read error message
locking/lockdep: Add debug_locks check in __lock_downgrade()
irqchip/gic-v3-its: Fix LPI release for Multi-MSI devices
f2fs: check all the data segments against all node ones
PCI: hv: Avoid use of hv_pci_dev->pci_slot after freeing it
blk-mq: move cancel of requeue_work to the front of blk_exit_queue
Revert "f2fs: avoid out-of-range memory access"
dm zoned: fix invalid memory access
f2fs: fix to do sanity check on segment bitmap of LFS curseg
drm: Flush output polling on shutdown
net: don't warn in inet diag when IPV6 is disabled
ACPI: video: Add new hw_changes_brightness quirk, set it on PB Easynote MZ35
xfs: don't crash on null attr fork xfs_bmapi_read
Bluetooth: btrtl: Additional Realtek 8822CE Bluetooth devices
f2fs: use generic EFSBADCRC/EFSCORRUPTED
arcnet: provide a buffer big enough to actually receive packets
cdc_ncm: fix divide-by-zero caused by invalid wMaxPacketSize
macsec: drop skb sk before calling gro_cells_receive
net/phy: fix DP83865 10 Mbps HDX loopback disable function
net: qrtr: Stop rx_worker before freeing node
net/sched: act_sample: don't push mac header on ip6gre ingress
net_sched: add max len check for TCA_KIND
openvswitch: change type of UPCALL_PID attribute to NLA_UNSPEC
ppp: Fix memory leak in ppp_write
sch_netem: fix a divide by zero in tabledist()
skge: fix checksum byte order
usbnet: ignore endpoints with invalid wMaxPacketSize
usbnet: sanity checking of packet sizes and device mtu
net/mlx5: Add device ID of upcoming BlueField-2
mISDN: enforce CAP_NET_RAW for raw sockets
appletalk: enforce CAP_NET_RAW for raw sockets
ax25: enforce CAP_NET_RAW for raw sockets
ieee802154: enforce CAP_NET_RAW for raw sockets
nfc: enforce CAP_NET_RAW for raw sockets
ALSA: hda: Flush interrupts on disabling
regulator: lm363x: Fix off-by-one n_voltages for lm3632 ldo_vpos/ldo_vneg
ASoC: sgtl5000: Fix charge pump source assignment
dmaengine: bcm2835: Print error in case setting DMA mask fails
leds: leds-lp5562 allow firmware files up to the maximum length
media: dib0700: fix link error for dibx000_i2c_set_speed
media: mtk-cir: lower de-glitch counter for rc-mm protocol
media: exynos4-is: fix leaked of_node references
media: hdpvr: Add device num check and handling
media: i2c: ov5640: Check for devm_gpiod_get_optional() error
sched/fair: Fix imbalance due to CPU affinity
sched/core: Fix CPU controller for !RT_GROUP_SCHED
x86/reboot: Always use NMI fallback when shutdown via reboot vector IPI fails
x86/apic: Soft disable APIC before initializing it
ALSA: hda - Show the fatal CORB/RIRB error more clearly
ALSA: i2c: ak4xxx-adda: Fix a possible null pointer dereference in build_adc_controls()
EDAC/mc: Fix grain_bits calculation
media: iguanair: add sanity checks
base: soc: Export soc_device_register/unregister APIs
ALSA: usb-audio: Skip bSynchAddress endpoint check if it is invalid
ia64:unwind: fix double free for mod->arch.init_unw_table
EDAC/altera: Use the proper type for the IRQ status bits
ASoC: rsnd: don't call clk_get_rate() under atomic context
md/raid1: end bio when the device faulty
md: don't call spare_active in md_reap_sync_thread if all member devices can't work
md: don't set In_sync if array is frozen
ACPI / processor: don't print errors for processorIDs == 0xff
EDAC, pnd2: Fix ioremap() size in dnv_rd_reg()
efi: cper: print AER info of PCIe fatal error
sched/fair: Use rq_lock/unlock in online_fair_sched_group
media: gspca: zero usb_buf on error
perf test vfs_getname: Disable ~/.perfconfig to get default output
media: mtk-mdp: fix reference count on old device tree
media: fdp1: Reduce FCP not found message level to debug
media: rc: imon: Allow iMON RC protocol for ffdc 7e device
dmaengine: iop-adma: use correct printk format strings
perf record: Support aarch64 random socket_id assignment
media: i2c: ov5645: Fix power sequence
media: omap3isp: Don't set streaming state on random subdevs
media: imx: mipi csi-2: Don't fail if initial state times-out
net: lpc-enet: fix printk format strings
ARM: dts: imx7d: cl-som-imx7: make ethernet work again
media: radio/si470x: kill urb on error
media: hdpvr: add terminating 0 at end of string
nbd: add missing config put
media: dvb-core: fix a memory leak bug
libperf: Fix alignment trap with xyarray contents in 'perf stat'
EDAC/amd64: Recognize DRAM device type ECC capability
EDAC/amd64: Decode syndrome before translating address
PM / devfreq: passive: Use non-devm notifiers
PM / devfreq: exynos-bus: Correct clock enable sequence
media: cec-notifier: clear cec_adap in cec_notifier_unregister
media: saa7146: add cleanup in hexium_attach()
media: cpia2_usb: fix memory leaks
media: saa7134: fix terminology around saa7134_i2c_eeprom_md7134_gate()
perf trace beauty ioctl: Fix off-by-one error in cmd->string table
media: ov9650: add a sanity check
ASoC: es8316: fix headphone mixer volume table
ACPI / CPPC: do not require the _PSD method
arm64: kpti: ensure patched kernel text is fetched from PoU
nvmet: fix data units read and written counters in SMART log
iommu/amd: Silence warnings under memory pressure
iommu/iova: Avoid false sharing on fq_timer_on
libtraceevent: Change users plugin directory
ARM: dts: exynos: Mark LDO10 as always-on on Peach Pit/Pi Chromebooks
ACPI: custom_method: fix memory leaks
ACPI / PCI: fix acpi_pci_irq_enable() memory leak
hwmon: (acpi_power_meter) Change log level for 'unsafe software power cap'
md/raid1: fail run raid1 array when active disk less than one
dmaengine: ti: edma: Do not reset reserved paRAM slots
kprobes: Prohibit probing on BUG() and WARN() address
s390/crypto: xts-aes-s390 fix extra run-time crypto self tests finding
ASoC: dmaengine: Make the pcm->name equal to pcm->id if the name is not set
raid5: don't set STRIPE_HANDLE to stripe which is in batch list
mmc: core: Clarify sdio_irq_pending flag for MMC_CAP2_SDIO_IRQ_NOTHREAD
mmc: sdhci: Fix incorrect switch to HS mode
raid5: don't increment read_errors on EILSEQ return
libertas: Add missing sentinel at end of if_usb.c fw_table
e1000e: add workaround for possible stalled packet
ALSA: hda - Drop unsol event handler for Intel HDMI codecs
drm/amd/powerplay/smu7: enforce minimal VBITimeout (v2)
media: ttusb-dec: Fix info-leak in ttusb_dec_send_command()
ALSA: hda/realtek - Blacklist PC beep for Lenovo ThinkCentre M73/93
btrfs: extent-tree: Make sure we only allocate extents from block groups with the same type
media: omap3isp: Set device on omap3isp subdevs
PM / devfreq: passive: fix compiler warning
ALSA: firewire-tascam: handle error code when getting current source of clock
ALSA: firewire-tascam: check intermediate state of clock status and retry
scsi: scsi_dh_rdac: zero cdb in send_mode_select()
printk: Do not lose last line in kmsg buffer dump
IB/hfi1: Define variables as unsigned long to fix KASAN warning
randstruct: Check member structs in is_pure_ops_struct()
ALSA: hda/realtek - Fixup mute led on HP Spectre x360
fuse: fix missing unlock_page in fuse_writepage()
parisc: Disable HP HSC-PCI Cards to prevent kernel crash
x86/retpolines: Fix up backport of a9d57ef15cbe
KVM: x86: always stop emulation on page fault
KVM: x86: set ctxt->have_exception in x86_decode_insn()
KVM: x86: Manually calculate reserved bits when loading PDPTRS
media: sn9c20x: Add MSI MS-1039 laptop to flip_dmi_table
binfmt_elf: Do not move brk for INTERP-less ET_EXEC
ASoC: Intel: NHLT: Fix debug print format
ASoC: Intel: Skylake: Use correct function to access iomem space
ASoC: Intel: Fix use of potentially uninitialized variable
ARM: samsung: Fix system restart on S3C6410
ARM: zynq: Use memcpy_toio instead of memcpy on smp bring-up
arm64: dts: rockchip: limit clock rate of MMC controllers for RK3328
alarmtimer: Use EOPNOTSUPP instead of ENOTSUPP
regulator: Defer init completion for a while after late_initcall
gfs2: clear buf_in_tr when ending a transaction in sweep_bh_for_rgrps
memcg, oom: don't require __GFP_FS when invoking memcg OOM killer
memcg, kmem: do not fail __GFP_NOFAIL charges
ovl: filter of trusted xattr results in audit
Btrfs: fix use-after-free when using the tree modification log
btrfs: Relinquish CPUs in btrfs_compare_trees
btrfs: qgroup: Fix the wrong target io_tree when freeing reserved data space
md/raid6: Set R5_ReadError when there is read failure on parity disk
md: don't report active array_state until after revalidate_disk() completes.
md: only call set_in_sync() when it is expected to succeed.
cfg80211: Purge frame registrations on iftype change
/dev/mem: Bail out upon SIGKILL.
ext4: fix warning inside ext4_convert_unwritten_extents_endio
ext4: fix punch hole for inline_data file systems
quota: fix wrong condition in is_quota_modification()
hwrng: core - don't wait on add_early_randomness()
i2c: riic: Clear NACK in tend isr
CIFS: fix max ea value size
CIFS: Fix oplock handling for SMB 2.1+ protocols
md/raid0: avoid RAID0 data corruption due to layout confusion.
mm/compaction.c: clear total_{migrate,free}_scanned before scanning a new zone
btrfs: qgroup: Drop quota_root and fs_info parameters from update_qgroup_status_item
Btrfs: fix race setting up and completing qgroup rescan workers
Linux 4.14.147

Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
22 files changed:
1  2 
Makefile
arch/arm64/kernel/cpufeature.c
arch/x86/Makefile
drivers/md/md.c
drivers/net/ppp/ppp_generic.c
drivers/power/supply/power_supply_sysfs.c
fs/ext4/inode.c
fs/f2fs/checkpoint.c
fs/f2fs/data.c
fs/f2fs/f2fs.h
fs/f2fs/inline.c
fs/f2fs/inode.c
fs/f2fs/node.c
fs/f2fs/recovery.c
fs/f2fs/segment.c
fs/f2fs/segment.h
fs/f2fs/super.c
fs/fuse/file.c
fs/overlayfs/inode.c
kernel/sched/core.c
kernel/sched/fair.c
mm/compaction.c

diff --cc Makefile
Simple merge
Simple merge
Simple merge
diff --cc drivers/md/md.c
Simple merge
Simple merge
diff --cc fs/ext4/inode.c
Simple merge
index 5029480e69f793506639bed571ec176f19a80612,170423ff272103aa6ca83549df09acf1f324c383..28739c0034b1b1f38c11351db998e0ac75e4ec78
@@@ -842,9 -793,9 +842,10 @@@ int f2fs_get_valid_checkpoint(struct f2
        unsigned int cp_blks = 1 + __cp_payload(sbi);
        block_t cp_blk_no;
        int i;
+       int err;
  
 -      sbi->ckpt = kzalloc(cp_blks * blk_size, GFP_KERNEL);
 +      sbi->ckpt = f2fs_kzalloc(sbi, array_size(blk_size, cp_blks),
 +                               GFP_KERNEL);
        if (!sbi->ckpt)
                return -ENOMEM;
        /*
                sbi->cur_cp_pack = 2;
  
        /* Sanity checking of checkpoint */
-       if (f2fs_sanity_check_ckpt(sbi))
 -      if (sanity_check_ckpt(sbi)) {
++      if (f2fs_sanity_check_ckpt(sbi)) {
+               err = -EFSCORRUPTED;
                goto free_fail_no_cp;
+       }
  
        if (cp_blks <= 1)
                goto done;
@@@ -911,8 -863,8 +915,8 @@@ free_fail_no_cp
        f2fs_put_page(cp1, 1);
        f2fs_put_page(cp2, 1);
  fail_no_cp:
 -      kfree(sbi->ckpt);
 +      kvfree(sbi->ckpt);
-       return -EINVAL;
+       return err;
  }
  
  static void __add_dirty_inode(struct inode *inode, enum inode_type type)
diff --cc fs/f2fs/data.c
Simple merge
diff --cc fs/f2fs/f2fs.h
index d0df6e9396b78da02bc2abdb7c99ecf56a8a638c,268409cee1c348ab016e35f386b679d969167e27..0ae019b79e0c4a20b66277558b9a7a9ade8a19a3
@@@ -3612,70 -3088,8 +3612,74 @@@ static inline bool f2fs_may_encrypt(str
  #endif
  }
  
 +static inline int block_unaligned_IO(struct inode *inode,
 +                              struct kiocb *iocb, struct iov_iter *iter)
 +{
 +      unsigned int i_blkbits = READ_ONCE(inode->i_blkbits);
 +      unsigned int blocksize_mask = (1 << i_blkbits) - 1;
 +      loff_t offset = iocb->ki_pos;
 +      unsigned long align = offset | iov_iter_alignment(iter);
 +
 +      return align & blocksize_mask;
 +}
 +
 +static inline int allow_outplace_dio(struct inode *inode,
 +                              struct kiocb *iocb, struct iov_iter *iter)
 +{
 +      struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
 +      int rw = iov_iter_rw(iter);
 +
 +      return (test_opt(sbi, LFS) && (rw == WRITE) &&
 +                              !block_unaligned_IO(inode, iocb, iter));
 +}
 +
 +static inline bool f2fs_force_buffered_io(struct inode *inode,
 +                              struct kiocb *iocb, struct iov_iter *iter)
 +{
 +      struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
 +      int rw = iov_iter_rw(iter);
 +
 +      if (f2fs_post_read_required(inode))
 +              return true;
 +      if (sbi->s_ndevs)
 +              return true;
 +      /*
 +       * for blkzoned device, fallback direct IO to buffered IO, so
 +       * all IOs can be serialized by log-structured write.
 +       */
 +      if (f2fs_sb_has_blkzoned(sbi))
 +              return true;
 +      if (test_opt(sbi, LFS) && (rw == WRITE) &&
 +                              block_unaligned_IO(inode, iocb, iter))
 +              return true;
 +      if (is_sbi_flag_set(F2FS_I_SB(inode), SBI_CP_DISABLED))
 +              return true;
 +
 +      return false;
 +}
 +
 +#ifdef CONFIG_F2FS_FAULT_INJECTION
 +extern void f2fs_build_fault_attr(struct f2fs_sb_info *sbi, unsigned int rate,
 +                                                      unsigned int type);
 +#else
 +#define f2fs_build_fault_attr(sbi, rate, type)                do { } while (0)
 +#endif
 +
 +static inline bool is_journalled_quota(struct f2fs_sb_info *sbi)
 +{
 +#ifdef CONFIG_QUOTA
 +      if (f2fs_sb_has_quota_ino(sbi))
 +              return true;
 +      if (F2FS_OPTION(sbi).s_qf_names[USRQUOTA] ||
 +              F2FS_OPTION(sbi).s_qf_names[GRPQUOTA] ||
 +              F2FS_OPTION(sbi).s_qf_names[PRJQUOTA])
 +              return true;
 +#endif
 +      return false;
 +}
 +
  #endif
+ #define EFSBADCRC     EBADMSG         /* Bad CRC detected */
+ #define EFSCORRUPTED  EUCLEAN         /* Filesystem is corrupted */
Simple merge
diff --cc fs/f2fs/inode.c
index 3cb80e6e31283337d1b94a22805bf49560162ad5,c6d0687f00fee6bc62ad3b811aa046cb944e4838..e9cd54afd14a5069118e2b6051c123fa3cf28986
@@@ -355,25 -298,9 +355,25 @@@ static int do_read_inode(struct inode *
        fi->i_extra_isize = f2fs_has_extra_attr(inode) ?
                                        le16_to_cpu(ri->i_extra_isize) : 0;
  
 +      if (f2fs_sb_has_flexible_inline_xattr(sbi)) {
 +              fi->i_inline_xattr_size = le16_to_cpu(ri->i_inline_xattr_size);
 +      } else if (f2fs_has_inline_xattr(inode) ||
 +                              f2fs_has_inline_dentry(inode)) {
 +              fi->i_inline_xattr_size = DEFAULT_INLINE_XATTR_ADDRS;
 +      } else {
 +
 +              /*
 +               * Previous inline data or directory always reserved 200 bytes
 +               * in inode layout, even if inline_xattr is disabled. In order
 +               * to keep inline_dentry's structure for backward compatibility,
 +               * we get the space back only from inline_data.
 +               */
 +              fi->i_inline_xattr_size = 0;
 +      }
 +
        if (!sanity_check_inode(inode, node_page)) {
                f2fs_put_page(node_page, 1);
-               return -EINVAL;
+               return -EFSCORRUPTED;
        }
  
        /* check data exist */
diff --cc fs/f2fs/node.c
Simple merge
Simple merge
index 9fdcda50fb025a85e762223689c757296522d821,9e5fca35e47d07cf0efb6b3b802f8493929751ba..5a61cf42ef749b07b0f8a6125d317e55908fcc73
@@@ -2774,7 -2216,8 +2774,7 @@@ int f2fs_trim_fs(struct f2fs_sb_info *s
        if (is_sbi_flag_set(sbi, SBI_NEED_FSCK)) {
                f2fs_msg(sbi->sb, KERN_WARNING,
                        "Found FS corruption, run fsck to fix.");
-               return -EIO;
 -              err = -EFSCORRUPTED;
 -              goto out;
++              return -EFSCORRUPTED;
        }
  
        /* start/end segment number in main_area */
Simple merge
diff --cc fs/f2fs/super.c
Simple merge
diff --cc fs/fuse/file.c
Simple merge
Simple merge
Simple merge
Simple merge
diff --cc mm/compaction.c
Simple merge