diff options
| author | Chen-Yu Tsai <wens@csie.org> | 2025-07-15 18:34:10 +0300 | 
|---|---|---|
| committer | Chen-Yu Tsai <wens@csie.org> | 2025-07-15 18:34:10 +0300 | 
| commit | ca5ad734d30f30a577f705926d6e16a87513a2a7 (patch) | |
| tree | b5fb169a86ac59892bd3b60c2df13e8a7cef360d /fs/smb/client/readdir.c | |
| parent | 082c6a2d06c0831d236760a29953355845eee988 (diff) | |
| parent | f99d4fccd2185176baf4ecac9a49d280fc62b953 (diff) | |
| download | linux-ca5ad734d30f30a577f705926d6e16a87513a2a7.tar.xz | |
Merge branch 'dt' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/linux-pm into sunxi/dt-for-6.17
Signed-off-by: Chen-Yu Tsai <wens@csie.org>
Diffstat (limited to 'fs/smb/client/readdir.c')
| -rw-r--r-- | fs/smb/client/readdir.c | 28 | 
1 files changed, 15 insertions, 13 deletions
| diff --git a/fs/smb/client/readdir.c b/fs/smb/client/readdir.c index f9f11cbf89be..ba0193cf9033 100644 --- a/fs/smb/client/readdir.c +++ b/fs/smb/client/readdir.c @@ -851,9 +851,9 @@ static bool emit_cached_dirents(struct cached_dirents *cde,  }  static void update_cached_dirents_count(struct cached_dirents *cde, -					struct dir_context *ctx) +					struct file *file)  { -	if (cde->ctx != ctx) +	if (cde->file != file)  		return;  	if (cde->is_valid || cde->is_failed)  		return; @@ -862,9 +862,9 @@ static void update_cached_dirents_count(struct cached_dirents *cde,  }  static void finished_cached_dirents_count(struct cached_dirents *cde, -					struct dir_context *ctx) +					struct dir_context *ctx, struct file *file)  { -	if (cde->ctx != ctx) +	if (cde->file != file)  		return;  	if (cde->is_valid || cde->is_failed)  		return; @@ -877,11 +877,12 @@ static void finished_cached_dirents_count(struct cached_dirents *cde,  static void add_cached_dirent(struct cached_dirents *cde,  			      struct dir_context *ctx,  			      const char *name, int namelen, -			      struct cifs_fattr *fattr) +			      struct cifs_fattr *fattr, +				  struct file *file)  {  	struct cached_dirent *de; -	if (cde->ctx != ctx) +	if (cde->file != file)  		return;  	if (cde->is_valid || cde->is_failed)  		return; @@ -911,7 +912,8 @@ static void add_cached_dirent(struct cached_dirents *cde,  static bool cifs_dir_emit(struct dir_context *ctx,  			  const char *name, int namelen,  			  struct cifs_fattr *fattr, -			  struct cached_fid *cfid) +			  struct cached_fid *cfid, +			  struct file *file)  {  	bool rc;  	ino_t ino = cifs_uniqueid_to_ino_t(fattr->cf_uniqueid); @@ -923,7 +925,7 @@ static bool cifs_dir_emit(struct dir_context *ctx,  	if (cfid) {  		mutex_lock(&cfid->dirents.de_mutex);  		add_cached_dirent(&cfid->dirents, ctx, name, namelen, -				  fattr); +				  fattr, file);  		mutex_unlock(&cfid->dirents.de_mutex);  	} @@ -1023,7 +1025,7 @@ static int cifs_filldir(char *find_entry, struct file *file,  	cifs_prime_dcache(file_dentry(file), &name, &fattr);  	return !cifs_dir_emit(ctx, name.name, name.len, -			      &fattr, cfid); +			      &fattr, cfid, file);  } @@ -1074,8 +1076,8 @@ int cifs_readdir(struct file *file, struct dir_context *ctx)  	 * we need to initialize scanning and storing the  	 * directory content.  	 */ -	if (ctx->pos == 0 && cfid->dirents.ctx == NULL) { -		cfid->dirents.ctx = ctx; +	if (ctx->pos == 0 && cfid->dirents.file == NULL) { +		cfid->dirents.file = file;  		cfid->dirents.pos = 2;  	}  	/* @@ -1143,7 +1145,7 @@ int cifs_readdir(struct file *file, struct dir_context *ctx)  	} else {  		if (cfid) {  			mutex_lock(&cfid->dirents.de_mutex); -			finished_cached_dirents_count(&cfid->dirents, ctx); +			finished_cached_dirents_count(&cfid->dirents, ctx, file);  			mutex_unlock(&cfid->dirents.de_mutex);  		}  		cifs_dbg(FYI, "Could not find entry\n"); @@ -1184,7 +1186,7 @@ int cifs_readdir(struct file *file, struct dir_context *ctx)  		ctx->pos++;  		if (cfid) {  			mutex_lock(&cfid->dirents.de_mutex); -			update_cached_dirents_count(&cfid->dirents, ctx); +			update_cached_dirents_count(&cfid->dirents, file);  			mutex_unlock(&cfid->dirents.de_mutex);  		} | 
