diff options
| author | Srinivasarao P <spathi@codeaurora.org> | 2018-11-28 11:42:49 +0530 | 
|---|---|---|
| committer | Srinivasarao P <spathi@codeaurora.org> | 2018-11-28 11:43:50 +0530 | 
| commit | 0a858409d5cd7283b8720d989bd2dba3f9353a6c (patch) | |
| tree | 6eb6fa078ff6630011688a9b57b6059e80f00401 /fs | |
| parent | f96a043350c0f9490ec98b48aecfcd6a8c477a98 (diff) | |
| parent | f34ff9e87b0564bd2ac1f3611d40313e80d20224 (diff) | |
Merge android-4.4.165 (f34ff9e) into msm-4.4
* refs/heads/tmp-f34ff9e
  Linux 4.4.165
  xhci: Fix USB3 NULL pointer dereference at logical disconnect.
  HID: uhid: forbid UHID_CREATE under KERNEL_DS or elevated privileges
  new helper: uaccess_kernel()
  ACPI / platform: Add SMB0001 HID to forbidden_id_list
  drivers/misc/sgi-gru: fix Spectre v1 vulnerability
  USB: misc: appledisplay: add 20" Apple Cinema Display
  misc: atmel-ssc: Fix section annotation on atmel_ssc_get_driver_data
  usb: quirks: Add delay-init quirk for Corsair K70 LUX RGB
  USB: quirks: Add no-lpm quirk for Raydium touchscreens
  usb: cdc-acm: add entry for Hiro (Conexant) modem
  uio: Fix an Oops on load
  media: v4l: event: Add subscription to list before calling "add" operation
  Revert "Bluetooth: h5: Fix missing dependency on BT_HCIUART_SERDEV"
  Revert "media: videobuf2-core: don't call memop 'finish' when queueing"
  btrfs: fix pinned underflow after transaction aborted
  gfs2: Put bitmap buffers in put_super
  SUNRPC: drop pointless static qualifier in xdr_get_next_encode_buffer()
  zram: close udev startup race condition as default groups
  lib/raid6: Fix arm64 test build
  hwmon: (ibmpowernv) Remove bogus __init annotations
  netfilter: xt_IDLETIMER: add sysfs filename checking routine
  netfilter: ipset: Correct rcu_dereference() call in ip_set_put_comment()
  s390/mm: Fix ERROR: "__node_distance" undefined!
  netfilter: ipset: actually allow allowable CIDR 0 in hash:net,port,net
  s390/vdso: add missing FORCE to build targets
  arm64: percpu: Initialize ret in the default case
  platform/x86: acerhdf: Add BIOS entry for Gateway LT31 v1.3307
  clk: samsung: exynos5420: Enable PERIS clocks for suspend
  fs/exofs: fix potential memory leak in mount option parsing
  um: Give start_idle_thread() a return code
  hfsplus: prevent btree data loss on root split
  hfs: prevent btree data loss on root split
  reiserfs: propagate errors from fill_with_dentries() properly
  x86/build: Use cc-option to validate stack alignment parameter
  x86/build: Fix stack alignment for CLang
  x86/boot: #undef memcpy() et al in string.c
  x86/build: Specify stack alignment for clang
  x86/build: Use __cc-option for boot code compiler options
  kbuild: Add __cc-option macro
  x86/mm/kaslr: Use the _ASM_MUL macro for multiplication to work around Clang incompatibility
  crypto, x86: aesni - fix token pasting for clang
  x86/kbuild: Use cc-option to enable -falign-{jumps/loops}
  arm64: Disable asm-operand-width warning for clang
  kbuild: allow to use GCC toolchain not in Clang search path
  kbuild: set no-integrated-as before incl. arch Makefile
  kbuild: clang: disable unused variable warnings only when constant
  kbuild: clang: remove crufty HOSTCFLAGS
  kbuild: clang: fix build failures with sparse check
  kbuild: move cc-option and cc-disable-warning after incl. arch Makefile
  kbuild: Set KBUILD_CFLAGS before incl. arch Makefile
  kbuild: fix linker feature test macros when cross compiling with Clang
  efi/libstub/arm64: Set -fpie when building the EFI stub
  efi/libstub/arm64: Force 'hidden' visibility for section markers
  crypto: arm64/sha - avoid non-standard inline asm tricks
  kbuild: clang: Disable 'address-of-packed-member' warning
  modules: mark __inittest/__exittest as __maybe_unused
  kbuild: Add support to generate LLVM assembly files
  kbuild: use -Oz instead of -Os when using clang
  kbuild, LLVMLinux: Add -Werror to cc-option to support clang
  kbuild: drop -Wno-unknown-warning-option from clang options
  kbuild: fix asm-offset generation to work with clang
  kbuild: consolidate redundant sed script ASM offset generation
  kbuild: Consolidate header generation from ASM offset information
  kbuild: clang: add -no-integrated-as to KBUILD_[AC]FLAGS
  kbuild: Add better clang cross build support
  ipv6: Fix PMTU updates for UDP/raw sockets in presence of VRF
  tg3: Add PHY reset for 5717/5719/5720 in change ring and flow control paths
  net-gro: reset skb->pkt_type in napi_reuse_skb()
  ip_tunnel: don't force DF when MTU is locked
  flow_dissector: do not dissect l4 ports for fragments
Conflicts:
	arch/um/os-Linux/skas/process.c
Change-Id: I6587d94332e204c068f7d44428a2ec1280bc3a7f
Signed-off-by: Srinivasarao P <spathi@codeaurora.org>
Diffstat (limited to 'fs')
| -rw-r--r-- | fs/btrfs/disk-io.c | 19 | ||||
| -rw-r--r-- | fs/exofs/super.c | 5 | ||||
| -rw-r--r-- | fs/gfs2/rgrp.c | 3 | ||||
| -rw-r--r-- | fs/hfs/brec.c | 4 | ||||
| -rw-r--r-- | fs/hfsplus/brec.c | 4 | ||||
| -rw-r--r-- | fs/reiserfs/xattr.c | 7 | 
6 files changed, 36 insertions, 6 deletions
| diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c index 8dbb00fbb00b..b0875ef48522 100644 --- a/fs/btrfs/disk-io.c +++ b/fs/btrfs/disk-io.c @@ -4333,6 +4333,7 @@ static int btrfs_destroy_marked_extents(struct btrfs_root *root,  static int btrfs_destroy_pinned_extent(struct btrfs_root *root,  				       struct extent_io_tree *pinned_extents)  { +	struct btrfs_fs_info *fs_info = root->fs_info;  	struct extent_io_tree *unpin;  	u64 start;  	u64 end; @@ -4342,21 +4343,31 @@ static int btrfs_destroy_pinned_extent(struct btrfs_root *root,  	unpin = pinned_extents;  again:  	while (1) { +		/* +		 * The btrfs_finish_extent_commit() may get the same range as +		 * ours between find_first_extent_bit and clear_extent_dirty. +		 * Hence, hold the unused_bg_unpin_mutex to avoid double unpin +		 * the same extent range. +		 */ +		mutex_lock(&fs_info->unused_bg_unpin_mutex);  		ret = find_first_extent_bit(unpin, 0, &start, &end,  					    EXTENT_DIRTY, NULL); -		if (ret) +		if (ret) { +			mutex_unlock(&fs_info->unused_bg_unpin_mutex);  			break; +		}  		clear_extent_dirty(unpin, start, end, GFP_NOFS);  		btrfs_error_unpin_extent_range(root, start, end); +		mutex_unlock(&fs_info->unused_bg_unpin_mutex);  		cond_resched();  	}  	if (loop) { -		if (unpin == &root->fs_info->freed_extents[0]) -			unpin = &root->fs_info->freed_extents[1]; +		if (unpin == &fs_info->freed_extents[0]) +			unpin = &fs_info->freed_extents[1];  		else -			unpin = &root->fs_info->freed_extents[0]; +			unpin = &fs_info->freed_extents[0];  		loop = false;  		goto again;  	} diff --git a/fs/exofs/super.c b/fs/exofs/super.c index b795c567b5e1..360ba74e04e6 100644 --- a/fs/exofs/super.c +++ b/fs/exofs/super.c @@ -100,6 +100,7 @@ static int parse_options(char *options, struct exofs_mountopt *opts)  		token = match_token(p, tokens, args);  		switch (token) {  		case Opt_name: +			kfree(opts->dev_name);  			opts->dev_name = match_strdup(&args[0]);  			if (unlikely(!opts->dev_name)) {  				EXOFS_ERR("Error allocating dev_name"); @@ -868,8 +869,10 @@ static struct dentry *exofs_mount(struct file_system_type *type,  	int ret;  	ret = parse_options(data, &opts); -	if (ret) +	if (ret) { +		kfree(opts.dev_name);  		return ERR_PTR(ret); +	}  	if (!opts.dev_name)  		opts.dev_name = dev_name; diff --git a/fs/gfs2/rgrp.c b/fs/gfs2/rgrp.c index c134c0462cee..ef24894edecc 100644 --- a/fs/gfs2/rgrp.c +++ b/fs/gfs2/rgrp.c @@ -732,6 +732,7 @@ void gfs2_clear_rgrpd(struct gfs2_sbd *sdp)  			spin_lock(&gl->gl_lockref.lock);  			gl->gl_object = NULL;  			spin_unlock(&gl->gl_lockref.lock); +			gfs2_rgrp_brelse(rgd);  			gfs2_glock_add_to_lru(gl);  			gfs2_glock_put(gl);  		} @@ -1139,7 +1140,7 @@ static u32 count_unlinked(struct gfs2_rgrpd *rgd)   * @rgd: the struct gfs2_rgrpd describing the RG to read in   *   * Read in all of a Resource Group's header and bitmap blocks. - * Caller must eventually call gfs2_rgrp_relse() to free the bitmaps. + * Caller must eventually call gfs2_rgrp_brelse() to free the bitmaps.   *   * Returns: errno   */ diff --git a/fs/hfs/brec.c b/fs/hfs/brec.c index 2a6f3c67cb3f..2e713673df42 100644 --- a/fs/hfs/brec.c +++ b/fs/hfs/brec.c @@ -424,6 +424,10 @@ skip:  	if (new_node) {  		__be32 cnid; +		if (!new_node->parent) { +			hfs_btree_inc_height(tree); +			new_node->parent = tree->root; +		}  		fd->bnode = hfs_bnode_find(tree, new_node->parent);  		/* create index key and entry */  		hfs_bnode_read_key(new_node, fd->search_key, 14); diff --git a/fs/hfsplus/brec.c b/fs/hfsplus/brec.c index 754fdf8c6356..1002a0c08319 100644 --- a/fs/hfsplus/brec.c +++ b/fs/hfsplus/brec.c @@ -427,6 +427,10 @@ skip:  	if (new_node) {  		__be32 cnid; +		if (!new_node->parent) { +			hfs_btree_inc_height(tree); +			new_node->parent = tree->root; +		}  		fd->bnode = hfs_bnode_find(tree, new_node->parent);  		/* create index key and entry */  		hfs_bnode_read_key(new_node, fd->search_key, 14); diff --git a/fs/reiserfs/xattr.c b/fs/reiserfs/xattr.c index 8b32fdaad468..d424b3d4bf3b 100644 --- a/fs/reiserfs/xattr.c +++ b/fs/reiserfs/xattr.c @@ -184,6 +184,7 @@ struct reiserfs_dentry_buf {  	struct dir_context ctx;  	struct dentry *xadir;  	int count; +	int err;  	struct dentry *dentries[8];  }; @@ -206,6 +207,7 @@ fill_with_dentries(struct dir_context *ctx, const char *name, int namelen,  	dentry = lookup_one_len(name, dbuf->xadir, namelen);  	if (IS_ERR(dentry)) { +		dbuf->err = PTR_ERR(dentry);  		return PTR_ERR(dentry);  	} else if (d_really_is_negative(dentry)) {  		/* A directory entry exists, but no file? */ @@ -214,6 +216,7 @@ fill_with_dentries(struct dir_context *ctx, const char *name, int namelen,  			       "not found for file %pd.\n",  			       dentry, dbuf->xadir);  		dput(dentry); +		dbuf->err = -EIO;  		return -EIO;  	} @@ -261,6 +264,10 @@ static int reiserfs_for_each_xattr(struct inode *inode,  		err = reiserfs_readdir_inode(d_inode(dir), &buf.ctx);  		if (err)  			break; +		if (buf.err) { +			err = buf.err; +			break; +		}  		if (!buf.count)  			break;  		for (i = 0; !err && i < buf.count && buf.dentries[i]; i++) { | 
