From owner-freebsd-hackers@FreeBSD.ORG Mon Dec 10 07:56:39 2012 Return-Path: Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [69.147.83.52]) by hub.freebsd.org (Postfix) with ESMTP id 5855CF1E for ; Mon, 10 Dec 2012 07:56:39 +0000 (UTC) (envelope-from aryeh.friedman@gmail.com) Received: from mail-oa0-f54.google.com (mail-oa0-f54.google.com [209.85.219.54]) by mx1.freebsd.org (Postfix) with ESMTP id 14EDB8FC14 for ; Mon, 10 Dec 2012 07:56:38 +0000 (UTC) Received: by mail-oa0-f54.google.com with SMTP id n9so2870565oag.13 for ; Sun, 09 Dec 2012 23:56:38 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type; bh=1o/0sqg5E/URvNlbRob/oSgIsFPPOm7rZ8dUiz2q7pQ=; b=OYnj3nGI1XUg2XYXJrvi/8OrJ9FuBfwtoGQ4GEPom5yniHxLCZEADyALa1Txu7LT0X Dq2XJTwHOFvRHgrFgr0x4apUfiNwqpru0MwOma1g+G6oWtyaM0BSxuK5Nq6FzUe23dTT vJXYLu67HyC4svVRt5g9jKA3wbbSMqMs0+9aniPkvDxATB7cEJpz1uZXxWtQMky8mum2 4TNR9LQhlq5dgcM4dOS9pqJe7yF8HEwwOR+qfb5Xf5PzO+1hchG1eeoFiKiBnFUQlZtR ZCj1O6aVPN+/LEZp3DV29XrXPd2zd3T/XqrqRWSyfOgDe54Hv+r2TEL2+14UH5IpjDiU nSdQ== MIME-Version: 1.0 Received: by 10.60.7.129 with SMTP id j1mr6953827oea.54.1355126198256; Sun, 09 Dec 2012 23:56:38 -0800 (PST) Received: by 10.182.158.137 with HTTP; Sun, 9 Dec 2012 23:56:38 -0800 (PST) In-Reply-To: References: Date: Mon, 10 Dec 2012 02:56:38 -0500 Message-ID: Subject: Re: using FreeBSD to create a completely new OS From: Aryeh Friedman To: Zaphod Beeblebrox Content-Type: text/plain; charset=ISO-8859-1 Cc: FreeBSD Mailing List X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 10 Dec 2012 07:56:39 -0000 On Mon, Dec 10, 2012 at 2:38 AM, Zaphod Beeblebrox wrote: > On Sun, Dec 9, 2012 at 11:48 PM, Aryeh Friedman > wrote: >> For personal hobby reasons I want to write an OS completely from >> scratch (due to some aspects of the design no existing OS is a >> suitable starting place)... what I mean is I want to start with the >> MBR (boot0) and go on from there... I only have one *REAL* machine to > > Well... most would say that the interesting part of an OS has very > little to do with the loader, but who am I to judge: maybe a loader is > interesting for you. There are quite a few things that can be loaded > and useful from an MBR. Pretty much any machine will provide you with > a boot environment that has lived longer than any other. It's pretty > much DOS without a filesystem, tho. In freebsd, you want to look at > /boot/mbr and maybe (later) /boot/loader (or one of it's variants). I was asking how to extract it from the virtual HDD made by vbox > >> work with which means I need to work with something like >> emulators/virtualbox-ose... I also want to do as many automated tests >> as possible (for example seeing if the installer copied the MBR [and >> later other stuff] correctly to the virtual HDD).... for this reason I >> have a few questions on vb (or perhaps QEMU if not possible in vb): >> >> 1. Can it be scripted? >> 2. Is there any documentation on the various virtual HDD formats and >> such (that way I can check the "physical" drive and not by indirect >> query)? > > The format of an MBR (master boot record) is documented everywhere. > I'm pretty sure wikipedia has a good article on it. This mailing list > is not google, BTW. I know (about the list not being google) and have seen the formats for MBR's (even wrote a few by hand) the question was how to extract it from the virtual HDD (see above).... namely is I have a prototype MBR that should be made I want to check if it was actually written to the virtual HDD correctly > >> Also can people give me some idea of a good general >> development/testing framework.... the one I have in mind so far is: >> >> 1. Write enough of the OS in FreeBSD to boot and give a command prompt >> and then develop using it (assume that there is a working compilor >> [note I am doing it completely in Java (note 1) and will be using >> either gjava (gcc) or writing my own compiler]) >> >> Notes: >> >> 1. Due to OS's needing to address physical RAM directly (DMA mapped >> I/O) I will be introducing some form of ptr's into java with the >> compiler or native > > My first thought was the humor of getting java to deal with segment > registers. It's hard enough in C. > > But in all seriousness, most systems go from the firmware to something > like a bootblock (often called a stage one boot) to a smarter > bootloader (stage two boot) to activating the OS. In a PC-ish world > for FreeBSD, that's BIOS->/boot/mbr->/boot/loader->kernel. > Specifically locore.s (note: assembly language file). locore.s is one > of a few regions of kernels that are generally _not_ written in high > level languages. Other's include the very lowest level of the > scheduler and the virtual memory manager. In locore's case, you can't > express the special instructions (for a PC) to exit real mode and > enter virtual mode (or some such transformation --- I really haven't > been there in awhile). Note that FreeBSD boots on a number of things > and that each boot process is a little bit different. The idea is not replicate *ANY* existing OS but write a completely new one (completely new architecture for an OS even). For that reason starting with the MBR is the right thing to do for reasons that would take several pages to explain. >From my initial research there is almost nothing that depends on actual ASM except for a very small number of things that create the environment needed to run the equiv of the JVM (no garbage collection at this level) natively on an x86. My guess the total amount of ASM needed is less then a thousand instructions (99% are macro's mostly for performance reasons). The other 1% is just to get the protected mode and the native JVM loaded and started. Note when I say JVM I actually mean a collection of VM's that model real HW (not some abstract HW like the sun JVM does) and if the VM just happens to be identical to the native HW then it skips the emulation part of the VM (i.e. direct execution on the actual HW). The first such VM I am planning is x86 (64-bit). Namely if your running on a PC then it runs natively but on anything else it runs on a VM identical to a PC. > > If you're going to write an OS from scratch, you might start with > something _way_ simpler than FreeBSD. Minix would be a good choice. > I think it still comes as a book you buy with bootable code. If you > haven't done OS work before, the book part might get you going faster > than diving into the FreeBSD codebase. I have done some trivial OS stuff before like getting to the point where I can type the equiv of ls and cd on a trivial virtual FS.