diff options
| author | Jonathan Cameron <Jonathan.Cameron@huawei.com> | 2025-09-13 15:00:48 +0100 | 
|---|---|---|
| committer | Jonathan Cameron <Jonathan.Cameron@huawei.com> | 2025-09-13 15:00:48 +0100 | 
| commit | 421d4487ef2ead206f57a8950ea9bdd1f7a7b39a (patch) | |
| tree | b679546eeaa70f88b5c8d6caeb79e214efb68121 /kernel/trace/ftrace.c | |
| parent | 3422b4bc606eee2ba7758ea9347c83332eeec3e3 (diff) | |
| parent | 1b237f190eb3d36f52dffe07a40b5eb210280e00 (diff) | |
Merge tag 'v6.17-rc3' into togreg
Linux 6.17-rc3
Diffstat (limited to 'kernel/trace/ftrace.c')
| -rw-r--r-- | kernel/trace/ftrace.c | 19 | 
1 files changed, 10 insertions, 9 deletions
| diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index 00b76d450a89..a69067367c29 100644 --- a/kernel/trace/ftrace.c +++ b/kernel/trace/ftrace.c @@ -4661,13 +4661,17 @@ ftrace_regex_open(struct ftrace_ops *ops, int flag,  	        } else {  			iter->hash = alloc_and_copy_ftrace_hash(size_bits, hash);  		} +	} else { +		if (hash) +			iter->hash = alloc_and_copy_ftrace_hash(hash->size_bits, hash); +		else +			iter->hash = EMPTY_HASH; +	} -		if (!iter->hash) { -			trace_parser_put(&iter->parser); -			goto out_unlock; -		} -	} else -		iter->hash = hash; +	if (!iter->hash) { +		trace_parser_put(&iter->parser); +		goto out_unlock; +	}  	ret = 0; @@ -6543,9 +6547,6 @@ int ftrace_regex_release(struct inode *inode, struct file *file)  		ftrace_hash_move_and_update_ops(iter->ops, orig_hash,  						      iter->hash, filter_hash);  		mutex_unlock(&ftrace_lock); -	} else { -		/* For read only, the hash is the ops hash */ -		iter->hash = NULL;  	}  	mutex_unlock(&iter->ops->func_hash->regex_lock); | 
