Hallo, ich sitze nun schon längere Zeit daran, mit einem Tiny2313 Daten über die UART einzulesen, diese in eine Tabelle zu schreiben und wieder über die UART auszugeben. Doch ich find das Problem nicht - wäre schön wenn mir jemand auf die Beine helfen könnte! Also die TX_Routine funktioniert super! Sobald ich aber ein RX an den Controller sende, bricht er den TX ab! Das zu lesende und zu sendende Signal entspricht dem DMX512-1990, also 250kBit/s, 1 Startbit, 8Datenbit + 2 Stoppbit - es gibt aber kein Startbyte. Mit TX_Reset wird ein Frame Error generiert! Die Anzahl der zu sendenden - zu empfangenden Bytes ist beschrenkt durch die Speichergröße (zu testzwecken ist es auf nur eine Hand voll Bytes reduziert). Im Anhang ist der Assebler Code beigefügt, ich bin für jede Hilfe dankbar! PS: habe sowas auf m mega16 schonmal zu laufen gebracht - finde im code aber keinen unterschied - bis auf die registernamen!
Hi!
Falsches Forum, Aber ok.
Habe nicht alles angeschaut aber was mir sofort auffällt:
; ***** define interrupt-vectors *****************************
.org 0x0000
rjmp RESET
.org INT0addr
rjmp E_INT0 ;External Interrupt0 Vector Address
.org INT1addr
rjmp E_INT1 ;External Interrupt1 Vector Address
.org ICP1addr
rjmp TIM1_CAPT ;Input Capture1 Interrupt Vector Address
.org OC1Aaddr
rjmp TIM1_COMPA ;Output Compare1A Interrupt Vector Address
.org OVF1addr
rjmp TIM1_OVF ;Overflow1 Interrupt Vector Address
.org OVF0addr
rjmp TIM0_OVF ;Overflow0 Interrupt Vector Address
.org URXC0addr
rjmp USART_RXC ;UART Receive Complete Interrupt Vector
Address
.org UDRE0addr
rjmp USART_UDRE ;UART Data Register Empty Interrupt Vector
Address
.org UTXC0addr
rjmp USART_TXC ;UART Transmit Complete Interrupt Vector
Address
.org ACIaddr
rjmp ANA_COMP ;Analog Comparator Interrupt Vector Address
;.org PCINTaddr
; rjmp PC_INT ;Pin Change Interrupt
.org OC1Baddr
rjmp TIM1_COMPB ;Timer/Counter1 Compare Match B
.org OC0Aaddr
rjmp TIM0_COMPA ;Timer/Counter0 Compare Match A
.org OC0Baddr
rjmp TIM0_COMPB ;Timer/Counter0 Compare Match B
.org USI_STARTaddr
rjmp USI_START ;USI start interrupt
.org USI_OVFaddr
rjmp USI_OVF ;USI overflow interrupt
.org ERDYaddr
rjmp ERDY ;EEPROM write complete
.org WDTaddr
rjmp WDT ;Watchdog Timer Interrupt
Der Assembler müsste eigentlich meckern weil da Sprungmarken stehen die
nicht da sind! Du benutzt wirklich alle Int.??? Ok Wenn nicht
freigegeben werden sie eigentlich auch nicht angesprungen, aber sauber
wäre eigentlich "reti" bei den ungenutzten. Nochwas, du solltest
immer schauen ob UDRE wirklich frei ist.
Viel Erfolg, Uwe
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.