diff --git a/testsuites/libtests/ChangeLog b/testsuites/libtests/ChangeLog index afb67d519d..aa2939bf13 100644 --- a/testsuites/libtests/ChangeLog +++ b/testsuites/libtests/ChangeLog @@ -1,3 +1,7 @@ +2010-07-01 Joel Sherrill + + * termios04/termios_testdriver_intr.c: Task driven IO now works. + 2010-07-01 Joel Sherrill * Makefile.am, configure.ac: Add test for task driven drivers. diff --git a/testsuites/libtests/termios04/termios_testdriver_intr.c b/testsuites/libtests/termios04/termios_testdriver_intr.c index 1ac57f0909..77a680253a 100644 --- a/testsuites/libtests/termios04/termios_testdriver_intr.c +++ b/testsuites/libtests/termios04/termios_testdriver_intr.c @@ -19,15 +19,23 @@ #include #include "termios_testdriver_intr.h" -rtems_id Timer; +rtems_id Rx_Timer; +rtems_id Tx_Timer; #define TX_MAX 1024 -uint8_t Tx_Buffer[TX_MAX]; -int Tx_Index = 0; +uint8_t Tx_Buffer[TX_MAX]; +int Tx_Index = 0; struct rtems_termios_tty *Ttyp; +void termios_test_driver_wait_for_tx_to_complete(void) +{ + rtems_task_wake_after( 2 * rtems_clock_get_ticks_per_second() ); +} + void termios_test_driver_dump_tx(const char *c) { + termios_test_driver_wait_for_tx_to_complete(); + printf( "%s %d characters\n", c, Tx_Index ); rtems_print_buffer( Tx_Buffer, Tx_Index ); Tx_Index = 0; @@ -39,6 +47,19 @@ int Rx_Length = 0; bool Rx_FirstTime = true; bool Rx_EnqueueNow = false; +#if defined(TASK_DRIVEN) + int termios_test_driver_inbyte_nonblocking( int port ) + { + if ( Rx_FirstTime == true ) { + Rx_FirstTime = false; + return -1; + } + if ( Rx_Index >= Rx_Length ) + return -1; + return Rx_Buffer[ Rx_Index++ ]; + } +#endif + rtems_timer_service_routine Rx_ISR( rtems_id ignored_id, void *ignored_address @@ -51,8 +72,21 @@ rtems_timer_service_routine Rx_ISR( ch = Rx_Buffer[ Rx_Index++ ]; rtems_termios_enqueue_raw_characters (Ttyp, (char *)&ch, 1); + #if defined(TASK_DRIVEN) + rtems_termios_rxirq_occured(Ttyp); + #endif - (void) rtems_timer_fire_after( Timer, 10, Rx_ISR, NULL ); + (void) rtems_timer_fire_after( Rx_Timer, 10, Rx_ISR, NULL ); +} + +rtems_timer_service_routine Tx_ISR( + rtems_id ignored_id, + void *ignored_address +) +{ + rtems_termios_dequeue_characters (Ttyp, 1); + + (void) rtems_timer_fire_after( Tx_Timer, 10, Tx_ISR, NULL ); } void termios_test_driver_set_rx_enqueue_now( @@ -72,7 +106,7 @@ void termios_test_driver_set_rx( Rx_Index = 0; if ( Rx_EnqueueNow == false) { - (void) rtems_timer_fire_after( Timer, 10, Rx_ISR, NULL ); + (void) rtems_timer_fire_after( Rx_Timer, 10, Rx_ISR, NULL ); return; } @@ -89,12 +123,9 @@ ssize_t termios_test_driver_write_helper( size_t len ) { - size_t i; - - for (i=0 ; i 2 ) {