-
Data: 2021-08-06 11:41:41
Temat: Re: Asembler 8080 - przerwania i zrzucanie stanu rejestrów na stos
Od: Atlantis <m...@w...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]On 06.08.2021 10:15, Zbych wrote:
> Wrzuć kod tego przerwania, a przynajmniej początek i koniec.
Poniżej. Z tego co widzę w chwili obecnej i tak zachowuję na stosie
więcej niż potrzeba - trafiają tam nawet te rejestry, których w danej
procedurze nie używam - pewnie pozostałość po jakichś eksperymentach.
Nie widzę tam jednak niczego, co mogłoby powodować takie kłopoty.
Wszystkie pary rejestrów są odkładane na stos i zdejmowane z niego we
właściwej kolejności.
W chwili obecnej jedyne aktywne przerwanie to te od timera, RTC oraz
klawiatury. Wszystkie pozostałe są wyłączone na poziomie kontrolera (8259).
;Interrupt routines
UART_RX_ISR:
PUSH PSW
PUSH H
PUSH D
POP D
POP H
POP PSW
EI
RET
UART_TX_ISR:
PUSH PSW
PUSH H
PUSH D
POP D
POP H
POP PSW
EI
RET
KBD_ISR:
PUSH PSW
PUSH H
PUSH D
IN KBD_DATA
STA KBDDATA
POP D
POP H
POP PSW
EI
RET
TIMER_ISR:
PUSH PSW
PUSH H
PUSH D
LHLD SYSTICK
INX H
SHLD SYSTICK
MVI A, 00H
OUT COUNT_REG_1_8253
MVI A, 0A0H
OUT COUNT_REG_1_8253
POP D
POP H
POP PSW
EI
RET
RTC_ISR:
PUSH PSW
PUSH H
PUSH D
MVI A, 00H
OUT RTC_CTRLD_REG
LHLD RTCTICK
INX H
SHLD RTCTICK
POP D
POP H
POP PSW
EI
RET
VDP_ISR:
PUSH PSW
PUSH H
PUSH D
POP D
POP H
POP PSW
EI
RET
;Interrupt vectors
IR0_VECT:
ORG 0FFE0H
EI
RET
NOP
NOP
IR1_VECT:
EI
RET
NOP
NOP
IR2_VECT:
JMP TIMER_ISR
NOP
IR3_VECT:
JMP UART_TX_ISR
NOP
IR4_VECT:
JMP UART_RX_ISR
NOP
IR5_VECT:
JMP KBD_ISR
NOP
IR6_VECT:
JMP RTC_ISR
NOP
IR7_VECT
JMP VDP_ISR
NOP
Następne wpisy z tego wątku
- 06.08.21 12:06 Atlantis
- 06.08.21 14:47 RoMan Mandziejewicz
- 06.08.21 15:00 Atlantis
- 06.08.21 15:14 Zbych
- 06.08.21 15:16 Janusz
- 07.08.21 11:25 Atlantis
- 09.08.21 10:54 J.F
Najnowsze wątki z tej grupy
- Thunderbird i dysk...
- opornosc falowa
- Bateria 9V 6F22, alkaliczna v cynkowa, samorozładowanie, bateria wysokiej trwałości do miernika
- Tani zakup z ali?
- w czasach LED komary mają ciężko
- walizka z kodami
- Rejestrator temperatur - termopara, siec
- Router LTE z możliwością zmian MTU
- Fajny film widziałem...
- Jaka ładowarka sieciowa do Iphona?
- Taśma izolacyjna do prac elektrycznych
- Recenzja 3.1A ;) w 6 gniazdach...
- Re: Recenzja 3.1A ;) w 6 gniazdach...
- Re: Recenzja 3.1A ;) w 6 gniazdach...
- Re: Recenzja 3.1A ;) w 6 gniazdach...
Najnowsze wątki
- 2025-07-25 Drastycznie rośnie import stali - w hucie w Dąbrowie Górniczej zostanie wygaszony wielki piec
- 2025-07-25 Drastycznie rośnie import stali - w hucie w Dąbrowie Górniczej zostanie wygaszony wielki piec
- 2025-07-25 I kolejny inżynier...
- 2025-07-25 Kobiety, bójcie się inżynierów...
- 2025-07-25 Warszawa => Konsultant Wiodący SAP PP <=
- 2025-07-25 Re: Brawo !!! Osy chronione w Niemczech. Za usunięcie gniazda grozi mandat
- 2025-07-25 cudzoziemiec bez biletu
- 2025-07-25 Gdynia => Sales Executive / KAM <=
- 2025-07-25 Inżynierzy z prawomocnym...
- 2025-07-25 Łódź => Mainframe (z/OS, Assembler) Developer <=
- 2025-07-25 Warszawa => Inżynier oprogramowania .Net <=
- 2025-07-25 Kraków => Senior Fullstack Engineer (Low-Code Platform) <=
- 2025-07-25 Skrobanie
- 2025-07-25 Lublin => Konsultant ds. Wdrożeń ERP (moduł FK) <=
- 2025-07-25 Warszawa => Senior Frontend Developer (React + React Native) <=