Benjamin Herrenschmidt writes: > On Sun, 2005-01-23 at 11:43 +1100, Benjamin Herrenschmidt wrote: > > > I know about this problem, I'm working on a proper fix. Thanks for your > > report. > > Can you send me the PVR value for both of these CPUs > (cat /proc/cpuinfo) ? I can't find right now why they would lock up > unless the default idle loop is _not_ run properly, that is for some > reason, NAP or DOZE mode end up not beeing enabled. Can you send me > your .config as well ?
=== cpuinfo.emac === processor : 0 cpu : 7447/7457, altivec supported clock : 1249MHz revision : 1.1 (pvr 8002 0101) bogomips : 830.66 machine : PowerMac6,4 motherboard : PowerMac6,4 MacRISC3 Power Macintosh detected as : 287 (Unknown Intrepid-based) pmac flags : 00000000 L2 cache : 512K unified memory : 256MB pmac-generation : NewWorld === cpuinfo.beige-g3 === processor : 0 cpu : 7455, altivec supported (a Sonnet G4 upgrade processor) clock : 66MHz <-- bogus, is 1.0GHz in reality revision : 2.1 (pvr 8001 0201) bogomips : 999.42 machine : Power Macintosh motherboard : AAPL,Gossamer MacRISC detected as : 48 (PowerMac G3 (Gossamer)) pmac flags : 00000000 memory : 768MB pmac-generation : OldWorld The .config files are a bit big, I'm sending them off-list. > Finally, try that patch and tell me if it makes a difference. It makes > sure we re-enable interrupts in cpu_idle, and thus should only be a > workaround. I found _one_ actual code path where we fail to re-enable > them, and this is when neither DOZE nor NAP mode is enabled, which > should not happen on any G3 (they should all support DOZE mode), and > might happe non some G4s if the chipset doesn't support NAP or > powersave_nap is set to 0 in proc, but that shouldn't be the case of an > eMac neither... > > --- linux-work.orig/arch/ppc/kernel/idle.c 2005-01-24 11:42:35.000000000 > +1100 > +++ linux-work/arch/ppc/kernel/idle.c 2005-01-24 12:19:41.114353760 > +1100 > @@ -39,17 +39,15 @@ > powersave = ppc_md.power_save; > > if (!need_resched()) { > + local_irq_enable(); > if (powersave != NULL) > powersave(); > else { > #ifdef CONFIG_SMP > set_thread_flag(TIF_POLLING_NRFLAG); > - local_irq_enable(); > while (!need_resched()) > barrier(); > clear_thread_flag(TIF_POLLING_NRFLAG); > -#else > - local_irq_enable(); > #endif > } > } Yes, this patch made the eMac boot Ok -- I can't test the Beige G3 until Friday. /Mikael - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/