On Thu, Mar 17, 2016 at 03:31:45PM +0900, Masao Uebayashi wrote:
> On Wed, Mar 16, 2016 at 11:26:39PM -0700, Mike Larkin wrote:
> > On Thu, Mar 17, 2016 at 03:15:07PM +0900, Masao Uebayashi wrote:
> > > This is the intended use, avoid busy-polling of BIOS PC console if
> > > running on HV.  Avoid 100% CPU usage at boot prompt on hypervisors.
> > > 
> > 
> > Which hypervisors have you tested this on?
> 
> VMware ESXi
> KVM
> QEMU

While I share some of Theo's concerns about testing this, this particular
diff seems ok to me. You probably at least need to get someone to test on
Hyper-V, and run these new bootblocks on a variety of machines (especially
older non-Intel/AMD i386 machines).

-ml

> 
> > -ml
> > 
> > > Originally I unconditionally reverted the polling part, which was
> > > introduced only for Intel Mac Mini.  After brief discussion with mikeb@,
> > > I decided to leave that hack by checking HV bit in CPUID (cpu_ecxfeature).
> > > 
> > > diff --git a/sys/arch/amd64/stand/libsa/bioscons.c 
> > > b/sys/arch/amd64/stand/libsa/bioscons.c
> > > index bdff9a4..fa42751 100644
> > > --- a/sys/arch/amd64/stand/libsa/bioscons.c
> > > +++ b/sys/arch/amd64/stand/libsa/bioscons.c
> > > @@ -30,6 +30,7 @@
> > >  
> > >  #include <machine/biosvar.h>
> > >  #include <machine/pio.h>
> > > +#include <machine/specialreg.h>
> > >  
> > >  #include <dev/cons.h>
> > >  #include <dev/ic/mc146818reg.h>
> > > @@ -37,7 +38,7 @@
> > >  #include <dev/ic/ns16450reg.h>
> > >  #include <dev/isa/isareg.h>
> > >  
> > > -#include <lib/libsa/stand.h>
> > > +#include <libsa.h>
> > >  
> > >  #include "biosdev.h"
> > >  
> > > @@ -82,14 +83,17 @@ pc_getc(dev_t dev)
> > >           return (rv & 0xff);
> > >   }
> > >  
> > > - /*
> > > -  * Wait for a character to actually become available.  Appears to
> > > -  * be necessary on (at least) the Intel Mac Mini.
> > > -  */
> > > - do {
> > > -         __asm volatile(DOINT(0x16) "; setnz %b0" : "=a" (rv) :
> > > -             "0" (0x100) : "%ecx", "%edx", "cc" );
> > > - } while ((rv & 0xff) == 0);
> > > + if ((cpu_ecxfeature & CPUIDECX_HV) == 0) {
> > > +         /*
> > > +                 * Wait for a character to actually become available.
> > > +                 * Appears to be necessary on (at least) the Intel Mac
> > > +                 * Mini.
> > > +          */
> > > +         do {
> > > +                 __asm volatile(DOINT(0x16) "; setnz %b0" : "=a" (rv) :
> > > +                     "0" (0x100) : "%ecx", "%edx", "cc" );
> > > +         } while ((rv & 0xff) == 0);
> > > + }
> > >  
> > >   __asm volatile(DOINT(0x16) : "=a" (rv) : "0" (0x000) :
> > >       "%ecx", "%edx", "cc" );
> > > diff --git a/sys/arch/i386/stand/libsa/bioscons.c 
> > > b/sys/arch/i386/stand/libsa/bioscons.c
> > > index 028bef3..b53abcf 100644
> > > --- a/sys/arch/i386/stand/libsa/bioscons.c
> > > +++ b/sys/arch/i386/stand/libsa/bioscons.c
> > > @@ -27,15 +27,20 @@
> > >   */
> > >  
> > >  #include <sys/types.h>
> > > +
> > >  #include <machine/biosvar.h>
> > >  #include <machine/pio.h>
> > > +#include <machine/specialreg.h>
> > > +
> > >  #include <dev/isa/isareg.h>
> > >  #include <dev/ic/mc146818reg.h>
> > >  #include <dev/ic/comreg.h>
> > >  #include <dev/ic/ns16450reg.h>
> > >  /* #include <i386/isa/nvram.h> */
> > >  #include <dev/cons.h>
> > > -#include <lib/libsa/stand.h>
> > > +
> > > +#include <libsa.h>
> > > +
> > >  #include "debug.h"
> > >  #include "biosdev.h"
> > >  
> > > @@ -80,14 +85,17 @@ pc_getc(dev_t dev)
> > >           return (rv & 0xff);
> > >   }
> > >  
> > > - /*
> > > -  * Wait for a character to actually become available.  Appears to
> > > -  * be necessary on (at least) the Intel Mac Mini.
> > > -  */
> > > - do {
> > > -         __asm volatile(DOINT(0x16) "; setnz %b0" : "=a" (rv) :
> > > -             "0" (0x100) : "%ecx", "%edx", "cc" );
> > > - } while ((rv & 0xff) == 0);
> > > + if ((cpu_ecxfeature & CPUIDECX_HV) == 0) {
> > > +         /*
> > > +                 * Wait for a character to actually become available.
> > > +                 * Appears to be necessary on (at least) the Intel Mac
> > > +                 * Mini.
> > > +          */
> > > +         do {
> > > +                 __asm volatile(DOINT(0x16) "; setnz %b0" : "=a" (rv) :
> > > +                     "0" (0x100) : "%ecx", "%edx", "cc" );
> > > +         } while ((rv & 0xff) == 0);
> > > + }
> > >  
> > >   __asm volatile(DOINT(0x16) : "=a" (rv) : "0" (0x000) :
> > >       "%ecx", "%edx", "cc" );
> > > 
> > > On Thu, Mar 17, 2016 at 02:58:58PM +0900, Masao Uebayashi wrote:
> > > > Factor out CPUID code in mdrandom(), invoke it once, then save the
> > > > result.  I'll use it to switch behavior depending on HV or not.
> > > > 
> > > > efiboot is not tested.
> > > > 
> > > > Comments?
> > > 
> > > > >From 104cb04bbbd0f7e40758938cc3103b2370a2285c Mon Sep 17 00:00:00 2001
> > > > From: Masao Uebayashi <uebay...@tombiinc.com>
> > > > Date: Thu, 10 Mar 2016 21:03:07 +0900
> > > > Subject: [PATCH 1/3] Factor out CPUID instruction in amd64 boot code
> > > > 
> > > > ---
> > > >  sys/arch/amd64/stand/boot/Makefile       |  1 +
> > > >  sys/arch/amd64/stand/boot/srt0.S         |  1 +
> > > >  sys/arch/amd64/stand/cdboot/Makefile     |  1 +
> > > >  sys/arch/amd64/stand/cdboot/srt0.S       |  2 +
> > > >  sys/arch/amd64/stand/libsa/cpuid.S       | 69 
> > > > ++++++++++++++++++++++++++++++++
> > > >  sys/arch/amd64/stand/libsa/libsa.h       |  7 ++++
> > > >  sys/arch/amd64/stand/libsa/random_i386.S | 22 +---------
> > > >  sys/arch/amd64/stand/pxeboot/Makefile    |  1 +
> > > >  sys/arch/amd64/stand/pxeboot/srt0.S      |  2 +
> > > >  9 files changed, 86 insertions(+), 20 deletions(-)
> > > >  create mode 100644 sys/arch/amd64/stand/libsa/cpuid.S
> > > > 
> > > > diff --git a/sys/arch/amd64/stand/boot/Makefile 
> > > > b/sys/arch/amd64/stand/boot/Makefile
> > > > index 359ea31..5811646 100644
> > > > --- a/sys/arch/amd64/stand/boot/Makefile
> > > > +++ b/sys/arch/amd64/stand/boot/Makefile
> > > > @@ -26,6 +26,7 @@ SRCS+=        boot.c bootarg.c cmd.c vars.c
> > > >  
> > > >  .PATH: ${SADIR}/libsa
> > > >  SRCS+= gidt.S random_i386.S
> > > > +SRCS+= cpuid.S
> > > >  SRCS+= cmd_i386.c dev_i386.c exec_i386.c gateA20.c machdep.c
> > > >  SRCS+= bioscons.c biosdev.c diskprobe.c memprobe.c time.c
> > > >  .if ${SOFTRAID:L} == "yes"
> > > > diff --git a/sys/arch/amd64/stand/boot/srt0.S 
> > > > b/sys/arch/amd64/stand/boot/srt0.S
> > > > index 9e1ede6..c2a5b2a 100644
> > > > --- a/sys/arch/amd64/stand/boot/srt0.S
> > > > +++ b/sys/arch/amd64/stand/boot/srt0.S
> > > > @@ -87,6 +87,7 @@ _start:
> > > >         rep;    stosb
> > > >  
> > > >         call    _ASM_LABEL(pmm_init)
> > > > +       call    _C_LABEL(initcpuid)
> > > >         call    _C_LABEL(boot)
> > > >  
> > > >         jmp     _C_LABEL(_rtt)
> > > > diff --git a/sys/arch/amd64/stand/cdboot/Makefile 
> > > > b/sys/arch/amd64/stand/cdboot/Makefile
> > > > index 23a261f..04ba1e9 100644
> > > > --- a/sys/arch/amd64/stand/cdboot/Makefile
> > > > +++ b/sys/arch/amd64/stand/cdboot/Makefile
> > > > @@ -19,6 +19,7 @@ BINMODE=644
> > > >  SRCS+= machdep.c dev_i386.c exec_i386.c cmd_i386.c
> > > >  SRCS+= gidt.S random_i386.S biosdev.c bioscons.c gateA20.c \
> > > >         memprobe.c diskprobe.c time.c
> > > > +SRCS+= cpuid.S
> > > >  SRCS+= softraid.c
> > > >  
> > > >  .PATH: ${S}/stand/boot
> > > > diff --git a/sys/arch/amd64/stand/cdboot/srt0.S 
> > > > b/sys/arch/amd64/stand/cdboot/srt0.S
> > > > index 82ff009..abe40d4 100644
> > > > --- a/sys/arch/amd64/stand/cdboot/srt0.S
> > > > +++ b/sys/arch/amd64/stand/cdboot/srt0.S
> > > > @@ -177,6 +177,8 @@ relocated:
> > > >         movl    %eax, _C_LABEL(bios_bootdev)
> > > >         movl    %eax, _C_LABEL(bios_cddev)
> > > >  
> > > > +       call    _C_LABEL(initcpuid)
> > > > +
> > > >         /*
> > > >          * Now call "main()".
> > > >          *
> > > > diff --git a/sys/arch/amd64/stand/libsa/cpuid.S 
> > > > b/sys/arch/amd64/stand/libsa/cpuid.S
> > > > new file mode 100644
> > > > index 0000000..c3ca1ac
> > > > --- /dev/null
> > > > +++ b/sys/arch/amd64/stand/libsa/cpuid.S
> > > > @@ -0,0 +1,69 @@
> > > > +/*     $OpenBSD$       */
> > > > +
> > > > +/*
> > > > + * Copyright (c) 2016 Masao Uebayashi <uebay...@tombiinc.com>
> > > > + * Copyright (c) 2013 Joel Sing <js...@openbsd.org>
> > > > + *
> > > > + * Permission to use, copy, modify, and distribute this software for 
> > > > any
> > > > + * purpose with or without fee is hereby granted, provided that the 
> > > > above
> > > > + * copyright notice and this permission notice appear in all copies.
> > > > + *
> > > > + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL 
> > > > WARRANTIES
> > > > + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
> > > > + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE 
> > > > FOR
> > > > + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY 
> > > > DAMAGES
> > > > + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN 
> > > > AN
> > > > + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING 
> > > > OUT OF
> > > > + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
> > > > + */
> > > > +
> > > > +#include <machine/param.h>
> > > > +#include <machine/asm.h>
> > > > +#include <machine/psl.h>
> > > > +#include <machine/specialreg.h>
> > > > +
> > > > +       .data
> > > > +
> > > > +       .globl  _C_LABEL(cpu_id)
> > > > +       .globl  _C_LABEL(cpu_feature)
> > > > +       .globl  _C_LABEL(cpu_ebxfeature)
> > > > +       .globl  _C_LABEL(cpu_ecxfeature)
> > > > +
> > > > +_C_LABEL(cpu_id):              .long   0
> > > > +_C_LABEL(cpu_feature):         .long   0
> > > > +_C_LABEL(cpu_ebxfeature):      .long   0
> > > > +_C_LABEL(cpu_ecxfeature):      .long   0
> > > > +
> > > > +       .text
> > > > +
> > > > +ENTRY(initcpuid)
> > > > +       pushal
> > > > +
> > > > +       // See if we have CPU identification.
> > > > +       pushfl
> > > > +       popl    %eax
> > > > +       movl    %eax, %ecx
> > > > +       orl     $PSL_ID, %eax
> > > > +       pushl   %eax
> > > > +       popfl
> > > > +       pushfl
> > > > +       popl    %eax
> > > > +       pushl   %ecx
> > > > +       popfl
> > > > +       andl    $PSL_ID, %eax
> > > > +       jz      done
> > > > +
> > > > +       // CPUID leaf = 1, subleaf = 0
> > > > +       movl    $1, %eax
> > > > +       movl    $0, %ecx
> > > > +       cpuid
> > > > +
> > > > +       movl    %eax, _C_LABEL(cpu_id)
> > > > +       movl    %ebx, _C_LABEL(cpu_ebxfeature)
> > > > +       movl    %ecx, _C_LABEL(cpu_ecxfeature)
> > > > +       movl    %edx, _C_LABEL(cpu_feature)
> > > > +
> > > > +done:
> > > > +       popal
> > > > +       ret
> > > > +END(initcpuid)
> > > > diff --git a/sys/arch/amd64/stand/libsa/libsa.h 
> > > > b/sys/arch/amd64/stand/libsa/libsa.h
> > > > index fc65c6f..1934078 100644
> > > > --- a/sys/arch/amd64/stand/libsa/libsa.h
> > > > +++ b/sys/arch/amd64/stand/libsa/libsa.h
> > > > @@ -77,3 +77,10 @@ extern u_int32_t bios_cksumlen;
> > > >  #define MACHINE_CMD    cmd_machine /* we have i386-specific commands */
> > > >  
> > > >  #define CHECK_SKIP_CONF        check_skip_conf /* we can skip 
> > > > boot.conf with Ctrl */
> > > > +
> > > > +/* cpuid.S */
> > > > +void initcpuid(void);
> > > > +extern u_int32_t cpu_id;
> > > > +extern u_int32_t cpu_feature;
> > > > +extern u_int32_t cpu_ebxfeature;
> > > > +extern u_int32_t cpu_ecxfeature;
> > > > diff --git a/sys/arch/amd64/stand/libsa/random_i386.S 
> > > > b/sys/arch/amd64/stand/libsa/random_i386.S
> > > > index 5e28b40..9d09379 100644
> > > > --- a/sys/arch/amd64/stand/libsa/random_i386.S
> > > > +++ b/sys/arch/amd64/stand/libsa/random_i386.S
> > > > @@ -28,34 +28,16 @@
> > > >  ENTRY(mdrandom)
> > > >         pushal
> > > >  
> > > > -       // See if we have CPU identification.
> > > > -       pushfl
> > > > -       popl    %eax
> > > > -       movl    %eax, %ecx
> > > > -       orl     $PSL_ID, %eax
> > > > -       pushl   %eax
> > > > -       popfl
> > > > -       pushfl
> > > > -       popl    %eax
> > > > -       pushl   %ecx
> > > > -       popfl
> > > > -       andl    $PSL_ID, %eax
> > > > -       jz      done
> > > > -
> > > > -       // CPUID leaf = 1, subleaf = 0
> > > > -       movl    $1, %eax
> > > > -       movl    $0, %ecx
> > > > -       cpuid
> > > > -       movl    %edx, %eax
> > > > -
> > > >         movl    36(%esp), %ebx
> > > >         movl    40(%esp), %edx
> > > >         xorl    %edi, %edi
> > > >  
> > > > +       movl    _C_LABEL(cpu_ecxfeature), %ecx
> > > >         andl    $CPUIDECX_RDRAND, %ecx  // See if we have rdrand.
> > > >         jnz     userand
> > > >  
> > > >         movl    %edx, %ecx
> > > > +       movl    _C_LABEL(cpu_feature), %eax
> > > >         andl    $CPUID_TSC, %eax        // See if we have rdtsc.
> > > >         jnz     usetsc
> > > >  
> > > > diff --git a/sys/arch/amd64/stand/pxeboot/Makefile 
> > > > b/sys/arch/amd64/stand/pxeboot/Makefile
> > > > index ddf2880..468c7f0 100644
> > > > --- a/sys/arch/amd64/stand/pxeboot/Makefile
> > > > +++ b/sys/arch/amd64/stand/pxeboot/Makefile
> > > > @@ -20,6 +20,7 @@ BINMODE=644
> > > >  SRCS+= machdep.c exec_i386.c cmd_i386.c
> > > >  SRCS+= gidt.S random_i386.S biosdev.c bioscons.c gateA20.c \
> > > >         memprobe.c diskprobe.c time.c ## biosprobe.c
> > > > +SRCS+= cpuid.S
> > > >  SRCS+= pxe.c pxe_call.S pxe_net.c pxe_udp.c
> > > >  SRCS+= softraid.c
> > > >  
> > > > diff --git a/sys/arch/amd64/stand/pxeboot/srt0.S 
> > > > b/sys/arch/amd64/stand/pxeboot/srt0.S
> > > > index 9c9226d..ee79225 100644
> > > > --- a/sys/arch/amd64/stand/pxeboot/srt0.S
> > > > +++ b/sys/arch/amd64/stand/pxeboot/srt0.S
> > > > @@ -172,6 +172,8 @@ relocated:
> > > >         movl    $pxe_progname, %eax
> > > >         movl    %eax, progname
> > > >  
> > > > +       call    _C_LABEL(initcpuid)
> > > > +
> > > >         /*
> > > >          * Now call "main()".
> > > >          *
> > > > -- 
> > > > 2.7.0
> > > > 
> > > 
> > > > >From c3072b7c101bd76d9c76b57bd317ce1829ebb153 Mon Sep 17 00:00:00 2001
> > > > From: Masao Uebayashi <uebay...@tombiinc.com>
> > > > Date: Thu, 17 Mar 2016 14:48:20 +0900
> > > > Subject: [PATCH 2/3] Implement CPUID in i386 boot loaders too
> > > > 
> > > > ---
> > > >  sys/arch/i386/stand/boot/Makefile    |  1 +
> > > >  sys/arch/i386/stand/boot/srt0.S      |  1 +
> > > >  sys/arch/i386/stand/cdboot/Makefile  |  1 +
> > > >  sys/arch/i386/stand/cdboot/srt0.S    |  2 ++
> > > >  sys/arch/i386/stand/libsa/cpuid.S    | 69 
> > > > ++++++++++++++++++++++++++++++++++++
> > > >  sys/arch/i386/stand/libsa/libsa.h    |  7 ++++
> > > >  sys/arch/i386/stand/pxeboot/Makefile |  1 +
> > > >  sys/arch/i386/stand/pxeboot/srt0.S   |  2 ++
> > > >  8 files changed, 84 insertions(+)
> > > >  create mode 100644 sys/arch/i386/stand/libsa/cpuid.S
> > > > 
> > > > diff --git a/sys/arch/i386/stand/boot/Makefile 
> > > > b/sys/arch/i386/stand/boot/Makefile
> > > > index 4339b82..c01c160 100644
> > > > --- a/sys/arch/i386/stand/boot/Makefile
> > > > +++ b/sys/arch/i386/stand/boot/Makefile
> > > > @@ -29,6 +29,7 @@ SRCS+=        boot.c bootarg.c cmd.c vars.c
> > > >  .PATH: ${SADIR}/libsa
> > > >  SRCS+= debug_i386.S
> > > >  SRCS+= gidt.S random_i386.S
> > > > +SRCS+= cpuid.S
> > > >  SRCS+= apmprobe.c debug.c pciprobe.c ps2probe.c
> > > >  SRCS+= cmd_i386.c dev_i386.c exec_i386.c gateA20.c machdep.c
> > > >  SRCS+= bioscons.c biosdev.c diskprobe.c memprobe.c time.c
> > > > diff --git a/sys/arch/i386/stand/boot/srt0.S 
> > > > b/sys/arch/i386/stand/boot/srt0.S
> > > > index 868b326..07f4240 100644
> > > > --- a/sys/arch/i386/stand/boot/srt0.S
> > > > +++ b/sys/arch/i386/stand/boot/srt0.S
> > > > @@ -87,6 +87,7 @@ _start:
> > > >         rep;    stosb
> > > >  
> > > >         call    _ASM_LABEL(pmm_init)
> > > > +       call    _C_LABEL(initcpuid)
> > > >         call    _C_LABEL(boot)
> > > >  
> > > >         jmp     _C_LABEL(_rtt)
> > > > diff --git a/sys/arch/i386/stand/cdboot/Makefile 
> > > > b/sys/arch/i386/stand/cdboot/Makefile
> > > > index 6306887..a533af4 100644
> > > > --- a/sys/arch/i386/stand/cdboot/Makefile
> > > > +++ b/sys/arch/i386/stand/cdboot/Makefile
> > > > @@ -18,6 +18,7 @@ CLEANFILES+=  crt0.o ${PROG}.whole
> > > >  
> > > >  .PATH: ${SADIR}/libsa
> > > >  SRCS+= debug_i386.S gidt.S random_i386.S
> > > > +SRCS+= cpuid.S
> > > >  SRCS+= cmd_i386.c dev_i386.c exec_i386.c gateA20.c machdep.c
> > > >  SRCS+= apmprobe.c bioscons.c biosdev.c debug.c diskprobe.c memprobe.c \
> > > >         pciprobe.c ps2probe.c time.c
> > > > diff --git a/sys/arch/i386/stand/cdboot/srt0.S 
> > > > b/sys/arch/i386/stand/cdboot/srt0.S
> > > > index 5a721e2..b9b1a19 100644
> > > > --- a/sys/arch/i386/stand/cdboot/srt0.S
> > > > +++ b/sys/arch/i386/stand/cdboot/srt0.S
> > > > @@ -177,6 +177,8 @@ relocated:
> > > >         movl    %eax, _C_LABEL(bios_bootdev)
> > > >         movl    %eax, _C_LABEL(bios_cddev)
> > > >  
> > > > +       call    _C_LABEL(initcpuid)
> > > > +
> > > >         /*
> > > >          * Now call "main()".
> > > >          *
> > > > diff --git a/sys/arch/i386/stand/libsa/cpuid.S 
> > > > b/sys/arch/i386/stand/libsa/cpuid.S
> > > > new file mode 100644
> > > > index 0000000..c3ca1ac
> > > > --- /dev/null
> > > > +++ b/sys/arch/i386/stand/libsa/cpuid.S
> > > > @@ -0,0 +1,69 @@
> > > > +/*     $OpenBSD$       */
> > > > +
> > > > +/*
> > > > + * Copyright (c) 2016 Masao Uebayashi <uebay...@tombiinc.com>
> > > > + * Copyright (c) 2013 Joel Sing <js...@openbsd.org>
> > > > + *
> > > > + * Permission to use, copy, modify, and distribute this software for 
> > > > any
> > > > + * purpose with or without fee is hereby granted, provided that the 
> > > > above
> > > > + * copyright notice and this permission notice appear in all copies.
> > > > + *
> > > > + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL 
> > > > WARRANTIES
> > > > + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
> > > > + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE 
> > > > FOR
> > > > + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY 
> > > > DAMAGES
> > > > + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN 
> > > > AN
> > > > + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING 
> > > > OUT OF
> > > > + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
> > > > + */
> > > > +
> > > > +#include <machine/param.h>
> > > > +#include <machine/asm.h>
> > > > +#include <machine/psl.h>
> > > > +#include <machine/specialreg.h>
> > > > +
> > > > +       .data
> > > > +
> > > > +       .globl  _C_LABEL(cpu_id)
> > > > +       .globl  _C_LABEL(cpu_feature)
> > > > +       .globl  _C_LABEL(cpu_ebxfeature)
> > > > +       .globl  _C_LABEL(cpu_ecxfeature)
> > > > +
> > > > +_C_LABEL(cpu_id):              .long   0
> > > > +_C_LABEL(cpu_feature):         .long   0
> > > > +_C_LABEL(cpu_ebxfeature):      .long   0
> > > > +_C_LABEL(cpu_ecxfeature):      .long   0
> > > > +
> > > > +       .text
> > > > +
> > > > +ENTRY(initcpuid)
> > > > +       pushal
> > > > +
> > > > +       // See if we have CPU identification.
> > > > +       pushfl
> > > > +       popl    %eax
> > > > +       movl    %eax, %ecx
> > > > +       orl     $PSL_ID, %eax
> > > > +       pushl   %eax
> > > > +       popfl
> > > > +       pushfl
> > > > +       popl    %eax
> > > > +       pushl   %ecx
> > > > +       popfl
> > > > +       andl    $PSL_ID, %eax
> > > > +       jz      done
> > > > +
> > > > +       // CPUID leaf = 1, subleaf = 0
> > > > +       movl    $1, %eax
> > > > +       movl    $0, %ecx
> > > > +       cpuid
> > > > +
> > > > +       movl    %eax, _C_LABEL(cpu_id)
> > > > +       movl    %ebx, _C_LABEL(cpu_ebxfeature)
> > > > +       movl    %ecx, _C_LABEL(cpu_ecxfeature)
> > > > +       movl    %edx, _C_LABEL(cpu_feature)
> > > > +
> > > > +done:
> > > > +       popal
> > > > +       ret
> > > > +END(initcpuid)
> > > > diff --git a/sys/arch/i386/stand/libsa/libsa.h 
> > > > b/sys/arch/i386/stand/libsa/libsa.h
> > > > index 76bf1e0..9539376 100644
> > > > --- a/sys/arch/i386/stand/libsa/libsa.h
> > > > +++ b/sys/arch/i386/stand/libsa/libsa.h
> > > > @@ -81,3 +81,10 @@ extern u_int32_t bios_cksumlen;
> > > >  #define MACHINE_CMD    cmd_machine /* we have i386-specific commands */
> > > >  
> > > >  #define CHECK_SKIP_CONF        check_skip_conf /* we can skip 
> > > > boot.conf with Ctrl */
> > > > +
> > > > +/* cpuid.S */
> > > > +void initcpuid(void);
> > > > +extern u_int32_t cpu_id;
> > > > +extern u_int32_t cpu_feature;
> > > > +extern u_int32_t cpu_ebxfeature;
> > > > +extern u_int32_t cpu_ecxfeature;
> > > > diff --git a/sys/arch/i386/stand/pxeboot/Makefile 
> > > > b/sys/arch/i386/stand/pxeboot/Makefile
> > > > index 9227246..f26e020 100644
> > > > --- a/sys/arch/i386/stand/pxeboot/Makefile
> > > > +++ b/sys/arch/i386/stand/pxeboot/Makefile
> > > > @@ -21,6 +21,7 @@ SRCS+=        debug_i386.S gidt.S random_i386.S
> > > >  SRCS+= cmd_i386.c exec_i386.c gateA20.c machdep.c
> > > >  SRCS+= apmprobe.c bioscons.c biosdev.c debug.c diskprobe.c memprobe.c \
> > > >         pciprobe.c ps2probe.c time.c
> > > > +SRCS+= cpuid.S
> > > >  SRCS+= pxe_call.S pxe.c pxe_net.c pxe_udp.c
> > > >  SRCS+= softraid.c
> > > >  
> > > > diff --git a/sys/arch/i386/stand/pxeboot/srt0.S 
> > > > b/sys/arch/i386/stand/pxeboot/srt0.S
> > > > index 16a0313..a62ee6a 100644
> > > > --- a/sys/arch/i386/stand/pxeboot/srt0.S
> > > > +++ b/sys/arch/i386/stand/pxeboot/srt0.S
> > > > @@ -172,6 +172,8 @@ relocated:
> > > >         movl    $pxe_progname, %eax
> > > >         movl    %eax, progname
> > > >  
> > > > +       call    _C_LABEL(initcpuid)
> > > > +
> > > >         /*
> > > >          * Now call "main()".
> > > >          *
> > > > -- 
> > > > 2.7.0
> > > > 
> > > 
> 

Reply via email to