svn commit: r353876 - head/sys/kern

Mark Johnston markj at freebsd.org
Tue Oct 22 15:40:41 UTC 2019


On Tue, Oct 22, 2019 at 08:29:13AM -0700, Gleb Smirnoff wrote:
>   Li-Wen,
> 
> On Tue, Oct 22, 2019 at 04:28:45PM +0800, Li-Wen Hsu wrote:
> L> > Modified: head/sys/kern/subr_epoch.c
> L> > ==============================================================================
> L> > --- head/sys/kern/subr_epoch.c  Mon Oct 21 21:21:34 2019        (r353875)
> L> > +++ head/sys/kern/subr_epoch.c  Mon Oct 21 23:12:14 2019        (r353876)
> L> > @@ -366,9 +366,13 @@ _epoch_enter_preempt(epoch_t epoch, epoch_tracker_t et
> L> >         struct thread *td;
> L> >
> L> >         MPASS(cold || epoch != NULL);
> L> > -       INIT_CHECK(epoch);
> L> >         MPASS(epoch->e_flags & EPOCH_PREEMPT);
> L> >         td = curthread;
> L> > +       MPASS((vm_offset_t)et >= td->td_kstack &&
> L> > +           (vm_offset_t)et + sizeof(struct epoch_tracker) <
> L> > +           td->td_kstack + td->td_kstack_pages * PAGE_SIZE);
> L> > +
> L> > +       INIT_CHECK(epoch);
> L> >  #ifdef EPOCH_TRACE
> L> >         epoch_trace_enter(td, epoch, et, file, line);
> L> >  #endif
> L> 
> L> Hello Gleb,
> L> 
> L> RISC-V boot panics with this message:
> L> 
> L> panic: Assertion (vm_offset_t)et >= td->td_kstack && (vm_offset_t)et +
> L> sizeof(struct epoch_tracker) < td->td_kstack + td->td_kstack_pages *
> L> PAGE_SIZE failed at /workspace/src/sys/kern/subr_epoch.c:373
> L> 
> L> Full log: https://ci.freebsd.org/job/FreeBSD-head-riscv64-test/12334/console
> L> 
> L> Can you help check this?
> 
> I need help from RISC-V experts.

I suspect the problem is that init_proc0() on several arches does not
initialize td_kstack_pages.  I will test this patch and commit if it
fixes the panic.

Note that on arm64 and riscv thread0's kernel stack is statically
allocated.

diff --git a/sys/arm/arm/machdep.c b/sys/arm/arm/machdep.c
index dc0a84404f02..990c3df49328 100644
--- a/sys/arm/arm/machdep.c
+++ b/sys/arm/arm/machdep.c
@@ -771,6 +771,7 @@ init_proc0(vm_offset_t kstack)
 {
 	proc_linkup0(&proc0, &thread0);
 	thread0.td_kstack = kstack;
+	thread0.td_kstack_pages = kstack_pages;
 	thread0.td_pcb = (struct pcb *)
 		(thread0.td_kstack + kstack_pages * PAGE_SIZE) - 1;
 	thread0.td_pcb->pcb_flags = 0;
diff --git a/sys/arm64/arm64/machdep.c b/sys/arm64/arm64/machdep.c
index 4356add12aa0..967e1deaa55e 100644
--- a/sys/arm64/arm64/machdep.c
+++ b/sys/arm64/arm64/machdep.c
@@ -745,6 +745,7 @@ init_proc0(vm_offset_t kstack)
 
 	proc_linkup0(&proc0, &thread0);
 	thread0.td_kstack = kstack;
+	thread0.td_kstack_pages = KSTACK_PAGES;
 	thread0.td_pcb = (struct pcb *)(thread0.td_kstack) - 1;
 	thread0.td_pcb->pcb_fpflags = 0;
 	thread0.td_pcb->pcb_fpusaved = &thread0.td_pcb->pcb_fpustate;
diff --git a/sys/riscv/riscv/machdep.c b/sys/riscv/riscv/machdep.c
index e01f7e42895d..07113534706e 100644
--- a/sys/riscv/riscv/machdep.c
+++ b/sys/riscv/riscv/machdep.c
@@ -658,6 +658,7 @@ init_proc0(vm_offset_t kstack)
 
 	proc_linkup0(&proc0, &thread0);
 	thread0.td_kstack = kstack;
+	thread0.td_kstack_pages = KSTACK_PAGES;
 	thread0.td_pcb = (struct pcb *)(thread0.td_kstack) - 1;
 	thread0.td_pcb->pcb_fpflags = 0;
 	thread0.td_frame = &proc0_tf;


More information about the svn-src-all mailing list