On Fri, 2006-08-04 at 13:41 -0700, Zachary Amsden wrote: > Instead, what paravirt-ops promises long > term is a way to get rid of the sub-architecture layer altogether. > Sub-arches like Voyager and Visual workstation have some strange > initialization requirements, interrupt controllers, and SMP handling. > Exactly the kind of thing which paravirt_ops is being designed to > indirect for hypervisors. Well ... I agree that in principle it's possible to have a kernel that would run on both voyager and a generic x86 system and, I'll admit, I tried to go that route before creating the subarchitectures. However, in practice, I think the cost really becomes too high ... for voyager, it becomes necessary really to intercept almost the entirety of the the SMP API. The purpose of the subarchitecture interface wasn't to eventually have some API description that would allow voyager to co-exist with more normal x86 systems. It was to allow voyager to make use of generic x86 while being completely different at the x86 SMP level. I really don't think there'll ever be another x86 machine that's as different from the APIC approach as the voyager VIC/QIC is. thus, I think the actual x86 interface is much better described by mach-generic, which abstracts out the interfaces necessary to the more standard APIC based SMP systems. James