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.