• úvod
  • témata
  • události
  • tržiště
  • diskuze
  • nástěnka
  • přihlásit
    registrace
    ztracené heslo?
    LITTLELIAssembler
    _FREZA_
    _FREZA_ --- ---
    thement: projdi si zdrojaky ecosu... ale jako 'jak malloc/free'? chces to na hrubym zeleze? pokud ti staci uplne primitivni alokator, tak by se asi dal pouzit extent(9) z BSD (teda, neni to pametovej alokator, ale al. ciselnejch rozsahu - coz je stejny)
    LITTLELI
    LITTLELI --- ---
    mozna je neco na http://linuxassembly.org
    implementace se daji udelat ruzne, zalezi na pozadavcich na tu implementaci.
    THEMENT
    THEMENT --- ---
    inu a tip na nejakou asm implementaci malloc like fce?
    _FREZA_
    _FREZA_ --- ---
    jojo. no ono i ta asbtrakce bylo nesnadny cteni kdyz sem to videl poprvy. ale zas ma clovek par desitek mega zdrojaku na okoukavani ;-)
    LITTLELI
    LITTLELI --- ---
    _FREZA_: jo a zaplatpanbu za tu abstrakci, by clovek z toho pad na hubu :(
    _FREZA_
    _FREZA_ --- ---
    lili: jo jasny (teda az na i386 detaily, ja znam akorat ARM a to este trochu ;). no u DMA de o to ze programujes brouka nekde mimo na sbernici, takze mu potrebujes dat "sbernicovou/fyzickou adresu" dat co prenasis (a ne tu virtualni). ale od presnejch detailu jsem kernelovejma API do znacny miry odstinenej.
    LITTLELI
    LITTLELI --- ---
    logika je prosta

    linearni adresa -> prepocet (strankovani) -> fyzicka adresa

    pojem fyzicka a linearni adresa splyva prave kdyz PG bit CR0 je nastaven na 0,
    nebo pri praci na 286.

    jak se v takovem pripade vosefujou ty DMA to ted nevim :)
    LITTLELI
    LITTLELI --- ---
    _FREZA_: jo vim o tom, ale mel jsem na mysli neco jineho.
    _FREZA_
    _FREZA_ --- ---
    littleli: "s fyzickou se nepracuje nikdy" no primo mozna ne, ale jak jinak by clovek moh programovat DMA enginy ;-). zpetny mapovani na fyzicky adresy je zasadni ficura.
    LITTLELI
    LITTLELI --- ---
    uf uf ja bych rekl jinak, interrupty v poho,
    akorat pri virtualizaci musi interrupt gate ukazovat na segment existujici v ram
    jinak mas double fault a z toho se uz nevylizes.
    to je asi to ne?

    realna adresa je co? to je mysleno jako fyzicka nebo linearni? s fyzickou se
    v podstate nepracuje nikdy a virtualni pamet to je je takova berlicka ne?
    _FREZA_
    _FREZA_ --- ---
    no, i386 neumim takze nevim presne, ale rek bych ze pred nastavenim mmu interrupty nepotrebujes... ;) no kdyztak to muzu vecer zkusit najit
    _FREZA_
    _FREZA_ --- ---
    jachymko: mno nevim, nedela se to tak ze se vypnou interrupty, nastavi se mmu, zapnou se interrupty? (aspon tusim ze takhle sem to videl pro ARM)
    LITTLELI
    LITTLELI --- ---
    nj ale to se stane :)) zase je dobry, ze je jasny kde to bylo.
    LITTLELI
    LITTLELI --- ---
    JACHYMKO: jen to napis, nikdo se ti smat nebude
    LITTLELI
    LITTLELI --- ---
    no mi to delame tak, ze mame po vstupu do PM nastavenou vlastnost zasobniku
    na to ze je to 16bitovy segment, coz samozrejme neni duvod k tomu aby to nefachcilo.
    zasobnik se plni od zhora, to mas take splneno ;)
    tam bude naka bota primo se segmenty...
    mas nejaky debug info k tomu? fakt to pada na tom movu?
    LITTLELI
    LITTLELI --- ---
    offset segmentu... a co se tyce tech deskriptoru vitej do sveta.
    ja uz ani nevim jak to presne funguje ;)
    LITTLELI
    LITTLELI --- ---
    AXTHEB: to je sluzba biosu :))
    AXTHEB
    AXTHEB --- ---
    ; emulace dalnopisu
    LITTLELI
    LITTLELI --- ---
    pasaz s kodem:

    stuj:   hlt
            jmp     stuj
    


    je podle mne moc roztomila :_))
    LITTLELI
    LITTLELI --- ---
    jak se vratit po resetu na spravne misto... ve vm86 se to nepodari! bud je zapotrebi real nebo ring0, ale to jsem nezkousel (proc asi):

    [bits 16]
    [org 100h]
    [section .bss]
    stack_end:
            resw    50
    stack_begin:
    
    [section .data]
    multitask:	db	'Program nelze spustit ve virtualnim rezimu!',13,10,'$'
    reset_msg:	db	'Pokud se cinnost pocitace zastavi pocitac vypnete!',13,10
    		db	'Signal reset byl zaslan procesoru... ',36
    digits:         db      '0123456789abcdef'
    model:          db      'model 0x$'
    revision:       db      ', revision 0x$'
    CRLF:		db	13,10,'$'
    
    [section .text]
    	smsw	ax
    	and	ax,1
    	jz	fajn
    	mov	ah,9
    	mov	dx,multitask
    	int	21h
    	ret				; konec programu	
    fajn:	mov	ah,9
    	mov	dx,reset_msg
    	int	21h
            cli
            push    word 40h
            pop     ds
            mov     ax,cs
            mov     word[67h],real
            mov     word[69h],ax            ; 0040h:67h
            mov     al,0fh
            out     70h,al
            jmp     delay
    delay:  mov     al,0ah
            out     71h,al
            mov     al,0fch			; shutdown processoru tj. 
            				; 1) navrat do realneho rezimu z prot.
            				; 2) provede se skok dle 0040:0067 hned po resetu
            out     64h,al			; nyni se provadi 'pomaly' reset
    stuj:   hlt				; pozastavi cinnost procesoru az
    					; do chvile, kdy se zresetuje
            jmp     stuj			; pouze pojistka pro prichod NMI
            nop
    real:   mov     ax,cs			; tady bude pokracovat nase rutina
            mov     ss,ax
            mov     ds,ax
            mov     es,ax                   ; ted jsou vsechny segm. reg rovny
            mov     sp,stack_begin		; nastaveni prozatimniho zasobniku
    	and	sp,0fffch		; zarovnani ??? zkusmo
            mov     al,0ffh
            out     64h,al                  ; povolit klavesnici
    	cld
            sti
            push    dx			; v DX je model a revize procesoru !!!
            mov     ah,9
            mov     dx,model
            int     21h			; napis model
            pop     ax
            push    ax
            mov     al,ah
            call    ByteToHex       	; napis cislo modelu
            mov     dx,revision
            mov     ah,9
            int     21h             	; retezec revize        
            pop     ax               	; tady je vysledek
            call    ByteToHex        	; napis cislo revize
    
            mov     ah,9
            mov     dx,CRLF
            int     21h             	; zaradkuj
    
            mov     ah,4ch
            int     21h                 	; navrat do DOSu
    
    ByteToHex:
            push    bx
            push    ax
            push    ax
            mov     bx,digits
            shr     al,4
            xlatb
            mov     ah,0eh
            int     10h         ; emulace dalnopisu
            pop     ax
            and     al,0fh
            xlatb
            mov     ah,0eh
            int     10h         ; emulace dalnopisu
            pop     ax
            pop     bx
            ret
    
    WordToHex:
            push    ax
            call    ByteToHex
            pop     ax
            mov     al,ah
            call    ByteToHex
            ret
    


    hehe, to jsem byl jeste pilna vcelka a komentoval kod ;)
    Kliknutím sem můžete změnit nastavení reklam