青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

JACKY_ZZ[貓貓愛吃魚]

春風拂面兩頰紅,秋葉灑地一片金。 夏荷搖曳一身輕,冬雪覆蓋大地銀。
posts - 30, comments - 123, trackbacks - 0, articles - 0

[ASM] boot.s

Posted on 2014-12-08 10:59 jacky_zz 閱讀(366) 評論(0)  編輯 收藏 引用 所屬分類: ASM
|
|    boot.s
|
| boot.s is loaded at 0x7c00 by the bios-startup routines, and moves itself
out of the way to address 0x90000, and jumps there.
|
| It then loads the system at 0x10000, using BIOS interrupts. Thereafter
| it disables all interrupts, moves the system down to 0x0000, changes
| to protected mode, and calls the start of system. System then must
| RE-initialize the protected mode in it's own tables, and enable
| interrupts as needed.
|
| NOTE! currently system is at most 8*65536 bytes long. This should be no
| problem, even in the future. I want to keep it simple. This 512 kB
| kernel size should be enough - in fact more would mean we'd have to move
| not just these start-up routines, but also do something about the cache-
| memory (block IO devices). The area left over in the lower 640 kB is meant
for these. No other memory is assumed to be "physical", ie all memory
| over 1Mb is demand-paging. All addresses under 1Mb are guaranteed to match
| their physical addresses.
|
| NOTE1 abouve is no longer valid in it's entirety. cache-memory is allocated
| above the 1Mb mark as well as below. Otherwise it is mainly correct.
|
| NOTE 2! The boot disk type must be set at compile-time, by setting
| the following equ. Having the boot-up procedure hunt for the right
| disk type is severe brain-damage.
| The loader has been made as simple as possible (had to, to get it
in 512 bytes with the code to move to protected mode), and continuos
| read errors will result in a unbreakable loop. Reboot by hand. It
| loads pretty fast by getting whole sectors at a time whenever possible.

| 1.44Mb disks:
sectors = 18
| 1.2Mb disks:
| sectors = 15
| 720kB disks:
| sectors = 9

.globl begtext, begdata, begbss, endtext, enddata, endbss
.text
begtext:
.data
begdata:
.bss
begbss:
.text

BOOTSEG = 0x07c0
INITSEG = 0x9000
SYSSEG  = 0x1000            | system loaded at 0x10000 (65536).
ENDSEG    = SYSSEG + SYSSIZE

entry start
start:
    mov    ax,#BOOTSEG
    mov    ds,ax
    mov    ax,#INITSEG
    mov    es,ax
    mov    cx,#256
    sub    si,si
    sub    di,di
    rep
    movw
    jmpi    go,INITSEG
go:    mov    ax,cs
    mov    ds,ax
    mov    es,ax
    mov    ss,ax
    mov    sp,#0x400        | arbitrary value >>512

    mov    ah,#0x03    | read cursor pos
    xor    bh,bh
    int    0x10
    
    mov    cx,#24
    mov    bx,#0x0007    | page 0, attribute 7 (normal)
    mov    bp,#msg1
    mov    ax,#0x1301    | write string, move cursor
    int    0x10

| ok, we've written the message, now
| we want to load the system (at 0x10000)

    mov    ax,#SYSSEG
    mov    es,ax        | segment of 0x010000
    call    read_it
    call    kill_motor

if the read went well we get current cursor position ans save it for
| posterity.

    mov    ah,#0x03    | read cursor pos
    xor    bh,bh
    int    0x10        | save it in known place, con_init fetches
    mov    [510],dx    | it from 0x90510.
        
| now we want to move to protected mode 

    cli            | no interrupts allowed !

| first we move the system to it's rightful place

    mov    ax,#0x0000
    cld            | 'direction'=0, movs moves forward
do_move:
    mov    es,ax        | destination segment
    add    ax,#0x1000
    cmp    ax,#0x9000
    jz    end_move
    mov    ds,ax        | source segment
    sub    di,di
    sub    si,si
    mov     cx,#0x8000
    rep
    movsw
    j    do_move

| then we load the segment descriptors

end_move:

    mov    ax,cs        | right, forgot this at first. didn't work :-)
    mov    ds,ax
    lidt    idt_48        | load idt with 0,0
    lgdt    gdt_48        | load gdt with whatever appropriate

| that was painless, now we enable A20

    call    empty_8042
    mov    al,#0xD1        | command write
    out    #0x64,al
    call    empty_8042
    mov    al,#0xDF        | A20 on
    out    #0x60,al
    call    empty_8042

| well, that went ok, I hope. Now we have to reprogram the interrupts :-(
| we put them right after the intel-reserved hardware interrupts, at
int 0x20-0x2F. There they won't mess up anything. Sadly IBM really
| messed this up with the original PC, and they haven't been able to
| rectify it afterwards. Thus the bios puts interrupts at 0x08-0x0f,
| which is used for the internal hardware interrupts as well. We just
| have to reprogram the 8259's, and it isn't fun.

    mov    al,#0x11        | initialization sequence
    out    #0x20,al        | send it to 8259A-1
    .word    0x00eb,0x00eb        | jmp $+2, jmp $+2
    out    #0xA0,al        | and to 8259A-2
    .word    0x00eb,0x00eb
    mov    al,#0x20        | start of hardware int's (0x20)
    out    #0x21,al
    .word    0x00eb,0x00eb
    mov    al,#0x28        | start of hardware int's 2 (0x28)
    out    #0xA1,al
    .word    0x00eb,0x00eb
    mov    al,#0x04        | 8259-1 is master
    out    #0x21,al
    .word    0x00eb,0x00eb
    mov    al,#0x02        | 8259-2 is slave
    out    #0xA1,al
    .word    0x00eb,0x00eb
    mov    al,#0x01        | 8086 mode for both
    out    #0x21,al
    .word    0x00eb,0x00eb
    out    #0xA1,al
    .word    0x00eb,0x00eb
    mov    al,#0xFF        | mask off all interrupts for now
    out    #0x21,al
    .word    0x00eb,0x00eb
    out    #0xA1,al

| well, that certainly wasn't fun :-(. Hopefully it works, and we don't
| need no steenking BIOS anyway (except for the initial loading :-).
| The BIOS-routine wants lots of unnecessary data, and it's less
| "interesting" anyway. This is how REAL programmers do it.
|
| Well, now's the time to actually move into protected mode. To make
| things as simple as possible, we do no register set-up or anything,
| we let the gnu-compiled 32-bit programs do that. We just jump to
| absolute address 0x00000, in 32-bit protected mode.

    mov    ax,#0x0001    | protected mode (PE) bit
    lmsw    ax        | This is it!
    jmpi    0,8        | jmp offset 0 of segment 8 (cs)

| This routine checks that the keyboard command queue is empty
| No timeout is used - if this hangs there is something wrong with
| the machine, and we probably couldn't proceed anyway.
empty_8042:
    .word    0x00eb,0x00eb
    in    al,#0x64    | 8042 status port
    test    al,#2        | is input buffer full?
    jnz    empty_8042    | yes - loop
    ret

| This routine loads the system at address 0x10000, making sure
| no 64kB boundaries are crossed. We try to load it as fast as
| possible, loading whole tracks whenever we can.
|
in:    es - starting address segment (normally 0x1000)
|
| This routine has to be recompiled to fit another drive type,
| just change the "sectors" variable at the start of the file
| (originally 18, for a 1.44Mb drive)
|
sread:    .word 1            | sectors read of current track
head:    .word 0            | current head
track:    .word 0            | current track
read_it:
    mov ax,es
    test ax,#0x0fff
die:    jne die            | es must be at 64kB boundary
    xor bx,bx        | bx is starting address within segment
rp_read:
    mov ax,es
    cmp ax,#ENDSEG        | have we loaded all yet?
    jb ok1_read
    ret
ok1_read:
    mov ax,#sectors
    sub ax,sread
    mov cx,ax
    shl cx,#9
    add cx,bx
    jnc ok2_read
    je ok2_read
    xor ax,ax
    sub ax,bx
    shr ax,#9
ok2_read:
    call read_track
    mov cx,ax
    add ax,sread
    cmp ax,#sectors
    jne ok3_read
    mov ax,#1
    sub ax,head
    jne ok4_read
    inc track
ok4_read:
    mov head,ax
    xor ax,ax
ok3_read:
    mov sread,ax
    shl cx,#9
    add bx,cx
    jnc rp_read
    mov ax,es
    add ax,#0x1000
    mov es,ax
    xor bx,bx
    jmp rp_read

read_track:
    push ax
    push bx
    push cx
    push dx
    mov dx,track
    mov cx,sread
    inc cx
    mov ch,dl
    mov dx,head
    mov dh,dl
    mov dl,#0
    and dx,#0x0100
    mov ah,#2
    int 0x13
    jc bad_rt
    pop dx
    pop cx
    pop bx
    pop ax
    ret
bad_rt:    mov ax,#0
    mov dx,#0
    int 0x13
    pop dx
    pop cx
    pop bx
    pop ax
    jmp read_track

/*
 * This procedure turns off the floppy drive motor, so
 * that we enter the kernel in a known state, and
 * don't have to worry about it later.
 
*/
kill_motor:
    push dx
    mov dx,#0x3f2
    mov al,#0
    outb
    pop dx
    ret

gdt:
    .word    0,0,0,0        | dummy

    .word    0x07FF        | 8Mb - limit=2047 (2048*4096=8Mb)
    .word    0x0000        | base address=0
    .word    0x9A00        | code read/exec
    .word    0x00C0        | granularity=4096, 386

    .word    0x07FF        | 8Mb - limit=2047 (2048*4096=8Mb)
    .word    0x0000        | base address=0
    .word    0x9200        | data read/write
    .word    0x00C0        | granularity=4096, 386

idt_48:
    .word    0            | idt limit=0
    .word    0,0            | idt base=0L

gdt_48:
    .word    0x800        | gdt limit=2048, 256 GDT entries
    .word    gdt,0x9        | gdt base = 0X9xxxx
    
msg1:
    .byte 13,10
    .ascii "Loading system "
    .byte 13,10,13,10

.text
endtext:
.data
enddata:
.bss
endbss:
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲激情国产| 亚洲黄网站黄| 欧美在线地址| 亚洲香蕉网站| 国产欧美一区二区精品性| 亚洲制服少妇| 亚洲图片欧洲图片av| 国产精自产拍久久久久久| 香蕉久久国产| 久久国产黑丝| 亚洲激情电影中文字幕| 亚洲理伦在线| 国产亚洲欧美另类中文| 久久免费视频在线| 中国日韩欧美久久久久久久久| 欧美一级视频免费在线观看| 欧美一级午夜免费电影| 亚洲国产精品久久久久秋霞蜜臀| 亚洲欧洲三级| 国产精品久久久久一区二区三区| 欧美一区免费视频| 久久美女性网| 国产精品99久久久久久久久| 亚洲香蕉成视频在线观看| 精品动漫一区| 亚洲另类自拍| 黄色日韩在线| av不卡在线观看| 伊人一区二区三区久久精品| 亚洲美女福利视频网站| 国内精品国语自产拍在线观看| 亚洲国产精品第一区二区| 欧美手机在线| 欧美成人精品一区| 国产精品视频xxx| 亚洲国产精品一区二区www在线 | 毛片一区二区三区| 欧美精品色网| 欧美不卡在线| 国产欧美视频一区二区| 最新国产成人av网站网址麻豆| 国产在线视频欧美一区二区三区| 亚洲麻豆一区| 亚洲精品久久久久中文字幕欢迎你 | 136国产福利精品导航网址| 一卡二卡3卡四卡高清精品视频 | 欧美黑人在线观看| 久久综合色88| 国产日产高清欧美一区二区三区| 亚洲日韩欧美视频| 亚洲国产欧美不卡在线观看| 午夜国产不卡在线观看视频| 亚洲视频在线观看三级| 欧美成人精品一区| 欧美成人国产一区二区| 国内免费精品永久在线视频| 一本大道久久精品懂色aⅴ | 欧美日韩一区综合| 亚洲精品国偷自产在线99热| 亚洲国产日韩一区| 久久久蜜桃精品| 久久视频在线视频| 国产一区二区你懂的| 亚洲一区在线播放| 午夜日韩在线| 国产精品萝li| 亚洲一区二区影院| 欧美在线视频不卡| 国产视频久久久久| 亚洲欧美另类久久久精品2019| 亚洲女同精品视频| 国产精品理论片| 亚洲欧美日韩成人高清在线一区| 亚洲电影在线观看| 欧美老女人xx| 亚洲乱码国产乱码精品精天堂 | 欧美日韩国产高清| 99精品欧美| 欧美亚洲三区| 狠狠久久亚洲欧美| 久久久久久有精品国产| 欧美成人r级一区二区三区| 亚洲国产精品毛片| 欧美日韩国产小视频在线观看| 99在线精品视频| 亚洲自拍高清| 国产一区二区三区日韩| 久久久久久亚洲综合影院红桃 | 久久亚洲综合色一区二区三区| 激情五月婷婷综合| 欧美国产日韩在线| 亚洲一区二区av电影| 久久色在线观看| 日韩午夜在线播放| 国产精品免费看| 久久午夜电影网| 日韩亚洲精品视频| 欧美在线视频免费观看| 136国产福利精品导航网址| 欧美精品色综合| 午夜激情综合网| 欧美激情亚洲国产| 午夜在线播放视频欧美| 在线日韩欧美| 欧美午夜不卡| 久久人人九九| 在线亚洲国产精品网站| 农夫在线精品视频免费观看| 一区二区三区日韩精品视频| 国产精品视频精品视频| 另类激情亚洲| 亚洲欧美经典视频| 亚洲国产精品一区二区第一页| 羞羞答答国产精品www一本| 亚洲国产电影| 国内精品久久久久影院色| 欧美日韩国产区一| 久久久久久久尹人综合网亚洲| 一本色道久久88综合亚洲精品ⅰ| 免费欧美在线视频| 亚洲欧美精品在线观看| 亚洲精品久久久久久久久久久久| 国产主播一区二区三区四区| 欧美日韩精品一区二区在线播放 | 亚洲在线视频一区| 亚洲精品视频在线播放| 欧美h视频在线| 欧美专区在线观看一区| 亚洲一区二区三区四区五区午夜| 在线欧美不卡| 激情视频一区二区| 国产视频在线观看一区二区| 国产精品海角社区在线观看| 欧美成人日本| 久久综合亚洲社区| 久久超碰97人人做人人爱| 欧美一级免费视频| 亚洲在线一区二区三区| 亚洲视频二区| 国产精品国产三级欧美二区| 亚洲桃色在线一区| 亚洲美女淫视频| 亚洲精一区二区三区| 亚洲激情一区二区| 亚洲国产日韩欧美综合久久| 欧美国产视频日韩| 亚洲国产裸拍裸体视频在线观看乱了中文 | 午夜激情久久久| 午夜精品久久久久| 欧美一区二区播放| 欧美在线观看一区二区三区| 亚洲欧美一级二级三级| 亚洲综合视频1区| 亚洲在线免费观看| 亚洲欧美视频在线观看视频| 亚洲欧美另类中文字幕| 亚洲男人的天堂在线观看| 性欧美8khd高清极品| 欧美在线观看视频一区二区三区| 久久成人免费电影| 久久久久九九九| 猛男gaygay欧美视频| 亚洲国产精品va| 99re视频这里只有精品| 亚洲图片激情小说| 久久精品免费| 免费日韩av| 欧美三区不卡| 国内综合精品午夜久久资源| 亚洲高清中文字幕| 国产精品99久久久久久有的能看| 亚洲欧美日韩另类精品一区二区三区| 翔田千里一区二区| 美女国产精品| 一本久久知道综合久久| 欧美在线视频不卡| 欧美激情二区三区| 国产欧美一区二区精品忘忧草 | 国产欧美精品一区| 亚洲成人在线| 亚洲一区二区视频| 美女视频网站黄色亚洲| 亚洲日本欧美天堂| 欧美在线国产精品| 欧美日本国产| 国内精品久久久久久久影视蜜臀| 亚洲另类自拍| 久久久久久久久久久久久9999| 亚洲国产精品久久久久秋霞蜜臀| 亚洲社区在线观看| 美女黄色成人网| 国产精品日韩一区二区| 亚洲精品久久久久久久久久久久久| 亚洲欧美激情视频| 亚洲国产精品一区二区www在线 | 亚洲成在人线av| 性18欧美另类| 欧美三级视频在线播放| 在线观看一区二区视频| 欧美一区二区视频在线观看|