POINT

From Atariki

(Różnice między wersjami)
Jump to: navigation, search
Wersja z dnia 09:30, 29 sie 2009
KMK (Dyskusja | wkład)

← Previous diff
Aktualna wersja
0xF (Dyskusja | wkład)
(przekazanie sektora i bajtu w asm)
Linia 1: Linia 1:
'''Przeznaczenie:''' Funkcja [[DOS]]-u ustawiająca bieżącą pozycję odczytu/zapisu w pliku, podaną w postaci numeru sektora i numeru bajtu w sektorze. Innymi słowy, ta pozycja to fizyczne koordynaty następnego bajtu, jaki zostanie odczytany lub zapisany podczas najbliższej operacji I/O na danym pliku. '''Przeznaczenie:''' Funkcja [[DOS]]-u ustawiająca bieżącą pozycję odczytu/zapisu w pliku, podaną w postaci numeru sektora i numeru bajtu w sektorze. Innymi słowy, ta pozycja to fizyczne koordynaty następnego bajtu, jaki zostanie odczytany lub zapisany podczas najbliższej operacji I/O na danym pliku.
-'''Dostępność:''' wszystkie [[DOS-y]] oprócz [[SpartaDOS]] ([[Real.DOS]]), [[SpartaDOS X]]+'''Dostępność:''' [[DOS 1.0]], [[DOS 2.0]], [[DOS 2.5]] i pochodne ([[MyDOS]])
'''Składnia [[Atari BASIC]]-a:''' <code>POINT #''iocb'',''sector'',''byte''</code> '''Składnia [[Atari BASIC]]-a:''' <code>POINT #''iocb'',''sector'',''byte''</code>
Linia 11: Linia 11:
lda #37 lda #37
sta iccmd,x sta iccmd,x
 + lda sector
 + sta icax3,x
 + lda sector+1
 + sta icax4,x
 + lda byte
 + sta icax5,x
jsr [[Tablica skoków#JCIOMAIN|jciomain]] jsr [[Tablica skoków#JCIOMAIN|jciomain]]
</code> </code>
Linia 17: Linia 23:
* ''iocb'' - numer kanału [[IOCB]] z zakresu od 1 do 7. Kanał ten w chwili wywołania funkcji musi być '''otwarty''' dla danego pliku. * ''iocb'' - numer kanału [[IOCB]] z zakresu od 1 do 7. Kanał ten w chwili wywołania funkcji musi być '''otwarty''' dla danego pliku.
-* ''sector'' - numer sektora (musi się mieścić w pliku otwartym przez kanał ''iocb'').+* ''sector'' - numer sektora przypisanego do pliku (musi się mieścić w pliku otwartym przez kanał ''iocb''). Jest to fizyczny numer sektora dyskietki, a nie numer kolejny sektora w pliku.
* ''byte'' - numer bajtu w sektorze (z zakresu od 0 do 255). * ''byte'' - numer bajtu w sektorze (z zakresu od 0 do 255).
-'''Uwagi:''' w SpartaDOS i pokrewnych ten sam kod operacyjny (XIO 37) zajmuje funkcja [[SEEK]].+'''Uwagi:''' w części DOS-ów ten sam kod operacyjny (XIO 37) zajmuje funkcja [[SEEK]].
'''Zwracana wartość:''' Procedura zwraca w rejestrze Y ujemny [[Kody błędów Atari OS|kod błędu]] albo wartość $01 w przypadku powodzenia, oraz odpowiednio do tego ustawia znacznik N rejestru znaczników. '''Zwracana wartość:''' Procedura zwraca w rejestrze Y ujemny [[Kody błędów Atari OS|kod błędu]] albo wartość $01 w przypadku powodzenia, oraz odpowiednio do tego ustawia znacznik N rejestru znaczników.
[[Kategoria:Niezbędnik kodera]] [[Kategoria:Niezbędnik kodera]]

Aktualna wersja

Przeznaczenie: Funkcja DOS-u ustawiająca bieżącą pozycję odczytu/zapisu w pliku, podaną w postaci numeru sektora i numeru bajtu w sektorze. Innymi słowy, ta pozycja to fizyczne koordynaty następnego bajtu, jaki zostanie odczytany lub zapisany podczas najbliższej operacji I/O na danym pliku.

Dostępność: DOS 1.0, DOS 2.0, DOS 2.5 i pochodne (MyDOS)

Składnia Atari BASIC-a: POINT #iocb,sector,byte

Kod w asemblerze:

    ldx #iocb*16
    lda #37
    sta iccmd,x
    lda sector
    sta icax3,x
    lda sector+1
    sta icax4,x
    lda byte
    sta icax5,x
    jsr jciomain

gdzie:

  • iocb - numer kanału IOCB z zakresu od 1 do 7. Kanał ten w chwili wywołania funkcji musi być otwarty dla danego pliku.
  • sector - numer sektora przypisanego do pliku (musi się mieścić w pliku otwartym przez kanał iocb). Jest to fizyczny numer sektora dyskietki, a nie numer kolejny sektora w pliku.
  • byte - numer bajtu w sektorze (z zakresu od 0 do 255).

Uwagi: w części DOS-ów ten sam kod operacyjny (XIO 37) zajmuje funkcja SEEK.

Zwracana wartość: Procedura zwraca w rejestrze Y ujemny kod błędu albo wartość $01 w przypadku powodzenia, oraz odpowiednio do tego ustawia znacznik N rejestru znaczników.

Personal tools