diff options
| author | Greg Kroah-Hartman <gregkh@google.com> | 2019-11-14 14:39:48 +0800 | 
|---|---|---|
| committer | Greg Kroah-Hartman <gregkh@google.com> | 2019-11-14 14:39:48 +0800 | 
| commit | ef0b39d33a38be556d95301c1b97e5d8afac1081 (patch) | |
| tree | 36ee8a8f25f1f294c7f3f747a3b8c1821d2decdc /fs/nfs/nfs4proc.c | |
| parent | e4575a2d22e1a6ff335ee354bc2a081639b5e99f (diff) | |
| parent | 6186d66524c25c70d634206dd460bd6388e7e9f9 (diff) | |
Merge 4.4.201 into android-4.4-p
Changes in 4.4.201
	CDC-NCM: handle incomplete transfer of MTU
	net: fix data-race in neigh_event_send()
	NFC: fdp: fix incorrect free object
	NFC: st21nfca: fix double free
	qede: fix NULL pointer deref in __qede_remove()
	nfc: netlink: fix double device reference drop
	ALSA: bebob: fix to detect configured source of sampling clock for Focusrite Saffire Pro i/o series
	ALSA: hda/ca0132 - Fix possible workqueue stall
	mm, vmstat: hide /proc/pagetypeinfo from normal users
	dump_stack: avoid the livelock of the dump_lock
	perf tools: Fix time sorting
	drm/radeon: fix si_enable_smc_cac() failed issue
	ceph: fix use-after-free in __ceph_remove_cap()
	iio: imu: adis16480: make sure provided frequency is positive
	netfilter: nf_tables: Align nft_expr private data to 64-bit
	netfilter: ipset: Fix an error code in ip_set_sockfn_get()
	can: usb_8dev: fix use-after-free on disconnect
	can: c_can: c_can_poll(): only read status register after status IRQ
	can: peak_usb: fix a potential out-of-sync while decoding packets
	can: gs_usb: gs_can_open(): prevent memory leak
	can: peak_usb: fix slab info leak
	drivers: usb: usbip: Add missing break statement to switch
	configfs: fix a deadlock in configfs_symlink()
	PCI: tegra: Enable Relaxed Ordering only for Tegra20 & Tegra30
	scsi: qla2xxx: fixup incorrect usage of host_byte
	scsi: lpfc: Honor module parameter lpfc_use_adisc
	ipvs: move old_secure_tcp into struct netns_ipvs
	bonding: fix unexpected IFF_BONDING bit unset
	usb: fsl: Check memory resource before releasing it
	usb: gadget: udc: atmel: Fix interrupt storm in FIFO mode.
	usb: gadget: composite: Fix possible double free memory bug
	usb: gadget: configfs: fix concurrent issue between composite APIs
	perf/x86/amd/ibs: Fix reading of the IBS OpData register and thus precise RIP validity
	USB: Skip endpoints with 0 maxpacket length
	scsi: qla2xxx: stop timer in shutdown path
	net: hisilicon: Fix "Trying to free already-free IRQ"
	NFSv4: Don't allow a cached open with a revoked delegation
	igb: Fix constant media auto sense switching when no cable is connected
	e1000: fix memory leaks
	can: flexcan: disable completely the ECC mechanism
	mm/filemap.c: don't initiate writeback if mapping has no dirty pages
	cgroup,writeback: don't switch wbs immediately on dead wbs if the memcg is dead
	net: prevent load/store tearing on sk->sk_stamp
	drm/i915/gtt: Add read only pages to gen8_pte_encode
	drm/i915/gtt: Read-only pages for insert_entries on bdw+
	drm/i915/gtt: Disable read-only support under GVT
	drm/i915: Rename gen7 cmdparser tables
	drm/i915: Disable Secure Batches for gen6+
	drm/i915: Remove Master tables from cmdparser
	drm/i915: Add support for mandatory cmdparsing
	drm/i915: Support ro ppgtt mapped cmdparser shadow buffers
	drm/i915: Allow parsing of unsized batches
	drm/i915: Add gen9 BCS cmdparsing
	drm/i915/cmdparser: Add support for backward jumps
	drm/i915/cmdparser: Ignore Length operands during command matching
	drm/i915: Lower RM timeout to avoid DSI hard hangs
	drm/i915/gen8+: Add RC6 CTX corruption WA
	drm/i915/cmdparser: Fix jump whitelist clearing
	Linux 4.4.201
Change-Id: Ifc1fa5b9734f244745b862c6dbf7e34b73245806
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
Diffstat (limited to 'fs/nfs/nfs4proc.c')
| -rw-r--r-- | fs/nfs/nfs4proc.c | 7 | 
1 files changed, 2 insertions, 5 deletions
| diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index 900a62a9ad4e..08207001d475 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c @@ -1243,8 +1243,6 @@ static int can_open_delegated(struct nfs_delegation *delegation, fmode_t fmode,  		return 0;  	if ((delegation->type & fmode) != fmode)  		return 0; -	if (test_bit(NFS_DELEGATION_RETURNING, &delegation->flags)) -		return 0;  	switch (claim) {  	case NFS4_OPEN_CLAIM_NULL:  	case NFS4_OPEN_CLAIM_FH: @@ -1473,7 +1471,6 @@ static void nfs4_return_incompatible_delegation(struct inode *inode, fmode_t fmo  static struct nfs4_state *nfs4_try_open_cached(struct nfs4_opendata *opendata)  {  	struct nfs4_state *state = opendata->state; -	struct nfs_inode *nfsi = NFS_I(state->inode);  	struct nfs_delegation *delegation;  	int open_mode = opendata->o_arg.open_flags;  	fmode_t fmode = opendata->o_arg.fmode; @@ -1490,7 +1487,7 @@ static struct nfs4_state *nfs4_try_open_cached(struct nfs4_opendata *opendata)  		}  		spin_unlock(&state->owner->so_lock);  		rcu_read_lock(); -		delegation = rcu_dereference(nfsi->delegation); +		delegation = nfs4_get_valid_delegation(state->inode);  		if (!can_open_delegated(delegation, fmode, claim)) {  			rcu_read_unlock();  			break; @@ -1981,7 +1978,7 @@ static void nfs4_open_prepare(struct rpc_task *task, void *calldata)  		if (can_open_cached(data->state, data->o_arg.fmode, data->o_arg.open_flags))  			goto out_no_action;  		rcu_read_lock(); -		delegation = rcu_dereference(NFS_I(data->state->inode)->delegation); +		delegation = nfs4_get_valid_delegation(data->state->inode);  		if (can_open_delegated(delegation, data->o_arg.fmode, claim))  			goto unlock_no_action;  		rcu_read_unlock(); | 
