POINT
From Atariki
(Różnice między wersjami)
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.