[vox-tech] definition of a virtual machine

Michael Wenk vox-tech@lists.lugod.org
Mon, 31 Mar 2003 16:28:24 -0800


On Monday 31 March 2003 12:39 pm, Peter Jay Salzman wrote:
> can someone tell me if this is a formally correct explanation of what a
> virtual machine is?
>
> pete
>
>
> A "real computer" provides an operating system many things, including a
> CPU, I/O channels, memory, a BIOS to provide low level access to
> motherboard and I/O resources, etc.  When an operating system wants to
> write to a hard drive, it communicates through a device driver that
> interfaces directly with the hardware device memory.
>
> However, it's possible to give a program all the hardware resources it
> needs.  When it wants to access a hard drive, give it some memory to
> write to.  When it wants to set an IRQ, give it some bogus instructions
> that lets it think it set an IRQ.  If you do this correctly, then in
> principle, there's no way for the application to know whether it's
> really accessing hardware or tricked by being given resources which
> simulate hardware.  A virtual machine is the environment which tricks
> applications into believing they're running on a real computer.  It
> provides all the services that a real computer would provide.
>
> VM's were used initially in the 1960's to emulate time shared operating
> systems, but these days we use them to run software which was written
> for foreign operating systems, or more commonly, an entire operating
> system.  Because of the nature of the VM, the foreign OS can't tell the
> difference between operating in a VM or in a "real" machine.
> _______________________________________________
> vox-tech mailing list
> vox-tech@lists.lugod.org
> http://lists.lugod.org/mailman/listinfo/vox-tech


Well, I can't find my old CS book, but I prefer the Java definition for a 
VM: 

"An abstract specification for a computing device that can be implemented in 
different ways, in software or hardware. ..." 

It goes on to more java and jvm specific information.  I think the 
important keyword is abstract.  You're definition is more specific, but 
a VM can describe just about any computing device, and arguably 
every computing device may not have the components you listed.  

Mike

--
wenk@praxis.homedns.org
Mike Wenk