tech-kern archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

Re: PowerBook 5xx instability fix.



On Sun, 30 Mar 2025 12:42:57 Taylor R Campbell wrote:
> > Date: Sun, 30 Mar 2025 11:29:38 +1100
> > From: Nat Sloss <nathanialsloss%yahoo.com.au@localhost>
> > 
> > The attached patch fixes it and I'd like to commit it if there are no
> > objections.
> > 
> >  	maxaddr = high[numranges - 1] - m68k_ptob(1);
> > 
> > -	high[numranges - 1] -= (m68k_round_page(MSGBUFSIZE) + m68k_ptob(1));
> > +	high[numranges - 1] -= (m68k_round_page(MSGBUFSIZE) + m68k_ptob(8));
> 
> Please put a comment here explaining what's going on.
> 
> Is maxaddr still correct?  Should you apply the same substitution on
> that line too?  If not, the comment must explain why maxaddr has
> m68k_ptob(1) subtracted while high[numranges - 1] has m68k_ptob(8)
> subtracted.

Is something like this OK?

Best regards,

Nat
diff -r d60e61cd41cf sys/arch/mac68k/mac68k/pmap_bootstrap.c
--- a/sys/arch/mac68k/mac68k/pmap_bootstrap.c	Sat Mar 29 01:43:38 2025 +0000
+++ b/sys/arch/mac68k/mac68k/pmap_bootstrap.c	Sun Mar 30 13:36:45 2025 +1100
@@ -503,7 +503,14 @@ pmap_bootstrap(paddr_t nextpa, paddr_t f
 	physmem = m68k_btop(avail_remaining + nextpa - firstpa);
 
 	maxaddr = high[numranges - 1] - m68k_ptob(1);
-	high[numranges - 1] -= (m68k_round_page(MSGBUFSIZE) + m68k_ptob(1));
+
+	/*
+	 * Reduce high by an extra 7 pages which seem to be used by the EASC
+	 * ascaudio(4) on some machines.  maxaddr is unchanged as the last page
+	 * can still be safetly used to reboot the system.
+	 */
+	high[numranges - 1] -= (m68k_round_page(MSGBUFSIZE) + m68k_ptob(8));
+
 	avail_end = high[numranges - 1];
 	mem_size = m68k_ptob(physmem);
 	virtual_end = VM_MAX_KERNEL_ADDRESS;


Home | Main Index | Thread Index | Old Index