#define MODULE_SIZE         1 * BLK_SIZE
#define BOOT_HIGH_LOC_HD    ((BOOT_RAM_LIMIT - (BOOT_STACK_SIZE + MODULE_SIZE)) >> 4)

DefinePrint("DD_BOOT_HIGH_LOC_HD", "%08X", BOOT_HIGH_LOC_HD << 4);

asm {
USE16
BHD_CODE::

#define BHD_START   (BHD_CODE - offset(CFAT32Boot.code))

                CLD

                MOV         AX, BOOT_HIGH_LOC_HD
                MOV         ES, AX

                CLI
                MOV         SS, AX
                MOV         SP, BOOT_STACK_SIZE + MODULE_SIZE
                STI

                CALL        BHD_GET_RIP
BHD_GET_RIP:
                POP         BX
                SUB         BX, BHD_GET_RIP - BHD_START
                SHR         BX, 4
//This copies this bootloader's code to 0x00096C00
                MOV         AX, CS
                ADD         AX, BX
                MOV         DS, AX
                MOV         CX, MODULE_SIZE
                XOR         SI, SI
                XOR         DI, DI
                REP_MOVSB

                MOV         AX, BOOT_HIGH_LOC_HD
                MOV         DS, AX

//The assembler doesn't support 16-bit very well.
                DU8         0xEA;   //JMP BOOT_HIGH_LOC_HD:BHD_HISTART
                DU16        BHD_HISTART - BHD_START, BOOT_HIGH_LOC_HD;

BHD_BIOS_DRIVE_NUM: DU8 0;

//Gets patched by BootHDIns().
BHD_BLK_COUNT:: DU16        0;

BHD_DAP:        DU8         16, 0, 1, 0; //One block at a time
BHD_DAP_BUF:    DU16        0, 0;
//Gets patched by BootHDIns().
BHD_DAP_BLK::   //64-bit
BHD_DAP_BLK_LO: DU32        0;
BHD_DAP_BLK_HI: DU32        0;

BHD_HISTART:
                MOV         U8 [BHD_BIOS_DRIVE_NUM - BHD_START], DL //Passed in by BIOS
                MOV         AX,  BOOT_RAM_BASE / 16
                MOV         ES,  AX
                XOR         ECX, ECX
                MOV         CX,  U16 [BHD_BLK_COUNT - BHD_START]

@@05:           PUSH        CX          //Block count

//READ BLOCK
                PUSH        ES          //Buf seg
                MOV         AX, ES
                MOV         U16 [BHD_DAP_BUF + 2 - BHD_START], AX //ES:0000
                MOV         SI, BHD_DAP - BHD_START //DS:SI=DAP
                MOV         AH, 0x42
                MOV         DL, U8 [BHD_BIOS_DRIVE_NUM - BHD_START]
                INT         0x13

                POP         AX          //ES
                ADD         AX, BLK_SIZE / 16
                MOV         ES, AX
                INC         U32 [BHD_DAP_BLK_LO - BHD_START]
                JNZ         @@10
                INC         U32 [BHD_DAP_BLK_HI - BHD_START]

@@10:           POP         CX
                LOOP        @@05

                XOR         EBX, EBX
                MOV         EAX, BOOT_SRC_HARDDRIVE //See sys_boot_src
//The assembler doesn't support 16-bit very well.
                DU8         0xEA;   //JMP BOOT_RAM_BASE:0000
                DU16        0, BOOT_RAM_BASE / 16;
//Continues here ::/Kernel/KStart16.CC
BHD_END::
#assert BHD_END - BHD_START < MODULE_SIZE - 2
}