How do I copy a bootloader to HDD image

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
Post Reply
User avatar
Thunderbirds747
Member
Member
Posts: 83
Joined: Sat Sep 17, 2016 2:14 am
Location: Moscow, Russia

How do I copy a bootloader to HDD image

Post by Thunderbirds747 »

Hello, I need some assistance. How do I copy boot.bin to empty HDD?
Any suggestions?
Sincerely, Tim. :?:
Coffee is not airplane fuel.
Bipman
Member
Member
Posts: 40
Joined: Wed Mar 15, 2017 9:22 am

Re: How do I copy a bootloader to HDD image

Post by Bipman »

Hi

Use something like HxD if you are using a PC as it will allow you to copy and paste from a bin file to the HD. It's how I get my code on to a boot HD in VirtualBox.

Bipman
User avatar
Schol-R-LEA
Member
Member
Posts: 1925
Joined: Fri Oct 27, 2006 9:42 am
Location: Athens, GA, USA

Re: How do I copy a bootloader to HDD image

Post by Schol-R-LEA »

EDIT: I noticed several serious errors in the earlier version of this, which I have now fixed (I hope). Mea culpa.

Any version of dd(1) (including WinDD or the Cygwin and MinGW ports) should work, pretty much the same way you would for a floppy image, except that sector 0 would need to be the MBR, and the boot block would be in whichever sector you define in the MBR's Partition Table as the start of the partition to use (probably sector 1, for a simple single-partition layout).

Note that if you have VirtualBox set to use UEFI booting (which it usually will if the underlying platform does, I think - corrections on this are welcome), you will want to use a GPT rather than a legacy partition table.

To actually create the image with a command-line dd(1), you might use something like:

Code: Select all

dd if=/dev/zero of="hdd.img" bs=512 count=<desired-img-size>
dd if="myMBR.bin" of="hdd.img" bs=512 count=1 conv=notrunc
dd if="myBoot.bin" of="hdd.img" bs=512 seek=1 count=1 conv=notrunc
dd if="myKernel.bin" of="hdd.img" bs=512 count=<kernel-size> seek=2 conv=notrunc
Keep in mind that bs, ibs and obs are in bytes, while seek, skip and count are in blocks of the ibs or obs sizes. Technically, both bs defaults to 512, and can be skipped here, but you probably want to have it explicitly despite this.

You can use suffixes to indicate the sizes as well. So, for a 100M image and a 1M kernel, you would have the MBR count as 200K and the kernel count as 2K.

Note also that /dev/zero is a part of Unixoid OSes like Linux; I am not sure offhand what to use in Windows instead. I have seen that some dd implementations for Windows mock up /dev/{null|zero|random|urandom} for cases like this, but I don't know if all of them do.
Last edited by Schol-R-LEA on Sun Apr 23, 2017 11:03 am, edited 3 times in total.
Rev. First Speaker Schol-R-LEA;2 LCF ELF JAM POEE KoR KCO PPWMTF
Ordo OS Project
Lisp programmers tend to seem very odd to outsiders, just like anyone else who has had a religious experience they can't quite explain to others.
User avatar
Thunderbirds747
Member
Member
Posts: 83
Joined: Sat Sep 17, 2016 2:14 am
Location: Moscow, Russia

Re: How do I copy a bootloader to HDD image

Post by Thunderbirds747 »

FYI, I use Windows. I need a special program in order to write it to the HDD not the floppy
Coffee is not airplane fuel.
User avatar
Schol-R-LEA
Member
Member
Posts: 1925
Joined: Fri Oct 27, 2006 9:42 am
Location: Athens, GA, USA

Re: How do I copy a bootloader to HDD image

Post by Schol-R-LEA »

Are you writing to an actual HDD, or to a disk image file? If it is a disk image, a Windows version of dd will work just fine as I described - it is what I was assuming (of stands for 'output file', and is used both for raw devices and for files).

If you are writing to a physical HDD, then... well, you'll need to use a partition manager first anyway, unless you are using an unformatted drive (which means, among other things, a drive other than the one you are developing on), in which case you are basically creating the partitions manually.

If you have already created a separate partition on the disk (whichever disk it is), then you should be able to use WinDD or something similar, though you may run into problems with Windows preventing it from touching an unformatted partition, or writing to the boot block of a formatted one.

For a real HDD, where a partition already exists, I think you would use something like

Code: Select all

dd if="myBoot.bin" of=\\.\\<drive-letter>: bs=512 count=1
dd if="myKernel.bin" of=\\.\\<drive-letter>: bs=512 seek=1
But don't take my word on it until at least one other person here confirms this.

Can anyone who knows Windows HDD partitioning and disk writing restrictions add anything?
Rev. First Speaker Schol-R-LEA;2 LCF ELF JAM POEE KoR KCO PPWMTF
Ordo OS Project
Lisp programmers tend to seem very odd to outsiders, just like anyone else who has had a religious experience they can't quite explain to others.
User avatar
Thunderbirds747
Member
Member
Posts: 83
Joined: Sat Sep 17, 2016 2:14 am
Location: Moscow, Russia

Re: How do I copy a bootloader to HDD image

Post by Thunderbirds747 »

Writing into the HDD image, my mate.
Coffee is not airplane fuel.
User avatar
matt11235
Member
Member
Posts: 286
Joined: Tue Aug 02, 2016 1:52 pm
Location: East Riding of Yorkshire, UK

Re: How do I copy a bootloader to HDD image

Post by matt11235 »

TimothyWilliams wrote:Writing into the HDD image, my mate.
dd will also write to a disk image.
com.sun.java.swing.plaf.nimbus.InternalFrameInternalFrameTitlePaneInternalFrameTitlePaneMaximizeButtonWindowNotFocusedState
Compiler Development Forum
User avatar
Thunderbirds747
Member
Member
Posts: 83
Joined: Sat Sep 17, 2016 2:14 am
Location: Moscow, Russia

Re: How do I copy a bootloader to HDD image

Post by Thunderbirds747 »

But WinDD does not work with my Windows (NT 10.0, 14393)
Coffee is not airplane fuel.
User avatar
Schol-R-LEA
Member
Member
Posts: 1925
Joined: Fri Oct 27, 2006 9:42 am
Location: Athens, GA, USA

Re: How do I copy a bootloader to HDD image

Post by Schol-R-LEA »

I'm not sure what you mean by 'HDD image" here, as 'image is somewhat overloaded. The term 'image' can refer to a simulated disk as a file, or as the raw disk data without taking into consideration of the format.

Let me put it another way: is this going onto the HDD itself as raw bytes, or as a file on the HDD in your parent file system (presumably C:\ or whatever drive you are developing on)?

Most of the time, you only use 'disk image' to refer to a raw copy of the hard disk when discussing backups - most of the time in OS dev, you are using a file to simulate the disk in something like VirtualBox or Bochs.

Careful and conscientious OS devs won't work with a real HDD until they have developed a utility for formatting the disk in their preferred file system format (FAT32, ext4, JFS, whatever it might be). By the time you are there, you aren't really talking about a disk image, you are generating the formatting based on the partition's structure.

Mind you, for either case you could use a Windows version of dd as described earlier, or something like RaWrite32 or the aforementioned HxD. They all should be able to do the trick for anything - disk images, floppies, hard drives, anything that can be written to as a file or block device, really.
Rev. First Speaker Schol-R-LEA;2 LCF ELF JAM POEE KoR KCO PPWMTF
Ordo OS Project
Lisp programmers tend to seem very odd to outsiders, just like anyone else who has had a religious experience they can't quite explain to others.
User avatar
Schol-R-LEA
Member
Member
Posts: 1925
Joined: Fri Oct 27, 2006 9:42 am
Location: Athens, GA, USA

Re: How do I copy a bootloader to HDD image

Post by Schol-R-LEA »

TimothyWilliams wrote:But WinDD does not work with my Windows (NT 10.0, 14393)
Huh. I didn't know that, but looking at the SF page, I see that it was last updated some time just before Windows 10 (which is the same as NT 10, but you probably knew that) was in general release. It seems HxD is even older (2009), so there's a good chance it won't work, either. Rawwrite32 is up to date as of last May, though, and Cygwin is as well if you don't mind messing around in the BASH shell emulator it provides (you could use Cygwin/X for some Unixoid things, but I don't think there are any graphical front ends on it for dd).

Rev. First Speaker Schol-R-LEA;2 LCF ELF JAM POEE KoR KCO PPWMTF
Ordo OS Project
Lisp programmers tend to seem very odd to outsiders, just like anyone else who has had a religious experience they can't quite explain to others.
User avatar
neon
Member
Member
Posts: 1567
Joined: Sun Feb 18, 2007 7:28 pm
Contact:

Re: How do I copy a bootloader to HDD image

Post by neon »

Since all you are trying to do is install a boot record to a disk image, why not just write a custom utility for doing it? It is trivial to write and can be extended later to detect the file system and automate the installation process. You already know what bytes need to be copied, so why not just write the code to do just that?
OS Development Series | Wiki | os | ncc
char c[2]={"\x90\xC3"};int main(){void(*f)()=(void(__cdecl*)(void))(void*)&c;f();}
User avatar
SpyderTL
Member
Member
Posts: 1074
Joined: Sun Sep 19, 2010 10:05 pm

Re: How do I copy a bootloader to HDD image

Post by SpyderTL »

Agreed. Just write your own. That's what I did.

If you can write an OS, you can probably write a Windows utility to copy some bytes to a file.
Project: OZone
Source: GitHub
Current Task: LIB/OBJ file support
"The more they overthink the plumbing, the easier it is to stop up the drain." - Montgomery Scott
User avatar
Schol-R-LEA
Member
Member
Posts: 1925
Joined: Fri Oct 27, 2006 9:42 am
Location: Athens, GA, USA

Re: How do I copy a bootloader to HDD image

Post by Schol-R-LEA »

I agree as well; as I said, this is what a sensible developer does once they are at the point of installing a live version of their OS on a hard drive, as it gives you full control over the process and the drive formatting.

That having been said, I am still not certain that you are actually at that stage, yet - it sounds as if you are just starting off still, and haven't gotten to the part where you are using a file system in your disk image (a more-or-less necessary first step before installing a bootable OS on a hard drive, or even a floppy that you want other OSes to be able to read).

Indeed, this is usually done when developing your second stage loader but before developing your actual kernel, because the usual practice is to have the kernel in an executable Object File format (e.g., ELF, PE) rather than a raw binary image, and have the second stage of the boot loader to read the file system directory structures and load the kernel as a normal executable file.

This is also part of why we recommend using an existing boot loader in the first place, if only because developing a boot loader yourself is a detour on the road to OS dev rather than a path to it, but you seem committed to this direction so I won't belabor the point.

However, using a file image as a scratch monkey when developing such a tool is also wise, anyway, so it would make a great deal of sense to go ahead and write your own disk utility well in advance of working with a real hard drive partition.
Rev. First Speaker Schol-R-LEA;2 LCF ELF JAM POEE KoR KCO PPWMTF
Ordo OS Project
Lisp programmers tend to seem very odd to outsiders, just like anyone else who has had a religious experience they can't quite explain to others.
Post Reply