mirror of
https://gitlab.rtems.org/rtems/rtos/rtems.git
synced 2025-12-08 00:23:14 +00:00
posix: Fix return states of pthread_kill()
POSIX mandates that an error code is returned and not -1 plus errno. Update #2715.
This commit is contained in:
@@ -28,7 +28,6 @@
|
||||
#include <rtems/posix/psignalimpl.h>
|
||||
#include <rtems/score/isr.h>
|
||||
#include <rtems/score/threadimpl.h>
|
||||
#include <rtems/seterr.h>
|
||||
|
||||
int pthread_kill(
|
||||
pthread_t thread,
|
||||
@@ -39,11 +38,9 @@ int pthread_kill(
|
||||
Thread_Control *the_thread;
|
||||
Objects_Locations location;
|
||||
|
||||
if ( !sig )
|
||||
rtems_set_errno_and_return_minus_one( EINVAL );
|
||||
|
||||
if ( !is_valid_signo(sig) )
|
||||
rtems_set_errno_and_return_minus_one( EINVAL );
|
||||
if ( !is_valid_signo( sig ) ) {
|
||||
return EINVAL;
|
||||
}
|
||||
|
||||
the_thread = _Thread_Get( thread, &location );
|
||||
switch ( location ) {
|
||||
@@ -55,19 +52,16 @@ int pthread_kill(
|
||||
|
||||
api = the_thread->API_Extensions[ THREAD_API_POSIX ];
|
||||
|
||||
if ( sig ) {
|
||||
|
||||
if ( _POSIX_signals_Vectors[ sig ].sa_handler == SIG_IGN ) {
|
||||
_Objects_Put( &the_thread->Object );
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* XXX critical section */
|
||||
|
||||
api->signals_pending |= signo_to_mask( sig );
|
||||
|
||||
(void) _POSIX_signals_Unblock_thread( the_thread, sig, NULL );
|
||||
if ( _POSIX_signals_Vectors[ sig ].sa_handler == SIG_IGN ) {
|
||||
_Objects_Put( &the_thread->Object );
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* XXX critical section */
|
||||
|
||||
api->signals_pending |= signo_to_mask( sig );
|
||||
|
||||
(void) _POSIX_signals_Unblock_thread( the_thread, sig, NULL );
|
||||
_Objects_Put( &the_thread->Object );
|
||||
return 0;
|
||||
|
||||
@@ -78,5 +72,5 @@ int pthread_kill(
|
||||
break;
|
||||
}
|
||||
|
||||
rtems_set_errno_and_return_minus_one( ESRCH );
|
||||
return ESRCH;
|
||||
}
|
||||
|
||||
@@ -543,15 +543,11 @@ void *POSIX_Init(
|
||||
puts( "Init: pthread_sigmask - EINVAL (timout->nsec invalid to large)" );
|
||||
|
||||
status = pthread_kill( Init_id, 999 );
|
||||
if ( status != -1 )
|
||||
printf( "status = %d\n", status );
|
||||
rtems_test_assert( errno == EINVAL );
|
||||
rtems_test_assert( status == EINVAL );
|
||||
puts( "Init: pthread_kill - EINVAL (sig invalid)" );
|
||||
|
||||
status = pthread_kill( Init_id, 0 );
|
||||
if ( status != -1 )
|
||||
printf( "status = %d\n", status );
|
||||
rtems_test_assert( errno == EINVAL );
|
||||
rtems_test_assert( status == EINVAL );
|
||||
puts( "Init: pthread_kill - EINVAL (signal = 0)" );
|
||||
|
||||
act.sa_handler = SIG_IGN;
|
||||
|
||||
Reference in New Issue
Block a user