Forum: Projekte & Code Probleme mit USART im Tiny2313


von Nicky (Gast)


Angehängte Dateien:

Lesenswert?

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!

von Uwe (Gast)


Lesenswert?

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
Noch kein Account? Hier anmelden.