From 74725b94127ab288137c5f0e5911abf8705fb6b0 Mon Sep 17 00:00:00 2001 From: xuxingliang Date: Thu, 22 Aug 2024 17:03:32 +0800 Subject: [PATCH] procfs: access tcb in critical section Signed-off-by: xuxingliang --- fs/procfs/fs_procfsproc.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/fs/procfs/fs_procfsproc.c b/fs/procfs/fs_procfsproc.c index e84f7311165dd..4ff7570d0bf44 100644 --- a/fs/procfs/fs_procfsproc.c +++ b/fs/procfs/fs_procfsproc.c @@ -1571,6 +1571,7 @@ static ssize_t proc_read(FAR struct file *filep, FAR char *buffer, { FAR struct proc_file_s *procfile; FAR struct tcb_s *tcb; + irqstate_t flags; ssize_t ret; finfo("buffer=%p buflen=%d\n", buffer, (int)buflen); @@ -1582,9 +1583,11 @@ static ssize_t proc_read(FAR struct file *filep, FAR char *buffer, /* Verify that the thread is still valid */ + flags = enter_critical_section(); tcb = nxsched_get_tcb(procfile->pid); if (tcb == NULL) { + leave_critical_section(flags); ferr("ERROR: PID %d is not valid\n", procfile->pid); return -ENODEV; } @@ -1644,6 +1647,8 @@ static ssize_t proc_read(FAR struct file *filep, FAR char *buffer, break; } + leave_critical_section(flags); + /* Update the file offset */ if (ret > 0)