forked from Imagelibrary/rtems
2004-05-06 Joel Sherrill <joel@OARcorp.com>
PR 618/rtems * include/rtems/rtems/status.h, src/clockget.c, src/clockset.c, src/dpmemcreate.c, src/dpmemexternal2internal.c, src/dpmeminternal2external.c, src/eventmp.c, src/eventreceive.c, src/eventsend.c, src/msgqbroadcast.c, src/msgqcreate.c, src/msgqflush.c, src/msgqgetnumberpending.c, src/msgqreceive.c, src/msgqsubmit.c, src/partcreate.c, src/partdelete.c, src/partgetbuffer.c, src/ratemoncancel.c, src/ratemoncreate.c, src/ratemondelete.c, src/ratemongetstatus.c, src/ratemonident.c, src/ratemonperiod.c, src/regioncreate.c, src/regiondelete.c, src/regionextend.c, src/regiongetsegment.c, src/regiongetsegmentsize.c, src/regionreturnsegment.c, src/semcreate.c, src/semdelete.c, src/semflush.c, src/semident.c, src/taskcreate.c, src/taskgetnote.c, src/taskmode.c, src/taskrestart.c, src/taskresume.c, src/tasksetnote.c, src/tasksuspend.c, src/taskvariableadd.c, src/taskvariabledelete.c, src/taskvariableget.c, src/taskwakewhen.c, src/timercreate.c, src/timerdelete.c, src/timerfireafter.c, src/timerfirewhen.c, src/timerserverfireafter.c, src/timerserverfirewhen.c: Add NULL checks.
This commit is contained in:
@@ -1,3 +1,26 @@
|
||||
2004-05-06 Joel Sherrill <joel@OARcorp.com>
|
||||
|
||||
PR 618/rtems
|
||||
* include/rtems/rtems/status.h, src/clockget.c, src/clockset.c,
|
||||
src/dpmemcreate.c, src/dpmemexternal2internal.c,
|
||||
src/dpmeminternal2external.c, src/eventmp.c, src/eventreceive.c,
|
||||
src/eventsend.c, src/msgqbroadcast.c, src/msgqcreate.c,
|
||||
src/msgqflush.c, src/msgqgetnumberpending.c, src/msgqreceive.c,
|
||||
src/msgqsubmit.c, src/partcreate.c, src/partdelete.c,
|
||||
src/partgetbuffer.c, src/ratemoncancel.c, src/ratemoncreate.c,
|
||||
src/ratemondelete.c, src/ratemongetstatus.c, src/ratemonident.c,
|
||||
src/ratemonperiod.c, src/regioncreate.c, src/regiondelete.c,
|
||||
src/regionextend.c, src/regiongetsegment.c,
|
||||
src/regiongetsegmentsize.c, src/regionreturnsegment.c,
|
||||
src/semcreate.c, src/semdelete.c, src/semflush.c, src/semident.c,
|
||||
src/taskcreate.c, src/taskgetnote.c, src/taskmode.c,
|
||||
src/taskrestart.c, src/taskresume.c, src/tasksetnote.c,
|
||||
src/tasksuspend.c, src/taskvariableadd.c, src/taskvariabledelete.c,
|
||||
src/taskvariableget.c, src/taskwakewhen.c, src/timercreate.c,
|
||||
src/timerdelete.c, src/timerfireafter.c, src/timerfirewhen.c,
|
||||
src/timerserverfireafter.c, src/timerserverfirewhen.c: Add NULL
|
||||
checks.
|
||||
|
||||
2004-02-26 Thomas Rauscher <trauscher@loytec.com.
|
||||
|
||||
PR 584/RTEMS
|
||||
|
||||
@@ -65,6 +65,7 @@ extern rtems_status_code _Status_Object_name_errors_to_status[];
|
||||
rtems_status_code _Status_Object_name_errors_to_status[] = {
|
||||
RTEMS_SUCCESSFUL, /* OBJECTS_SUCCESSFUL */
|
||||
RTEMS_INVALID_NAME, /* OBJECTS_INVALID_NAME */
|
||||
RTEMS_INVALID_ADDRESS, /* OBJECTS_INVALID_ADDRESS */
|
||||
RTEMS_INVALID_NODE /* OBJECTS_INVALID_NODE */
|
||||
};
|
||||
#endif
|
||||
|
||||
@@ -45,6 +45,9 @@ rtems_status_code rtems_clock_get(
|
||||
ISR_Level level;
|
||||
rtems_interval tmp;
|
||||
|
||||
if ( !time_buffer )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
switch ( option ) {
|
||||
case RTEMS_CLOCK_GET_TOD:
|
||||
if ( !_TOD_Is_set )
|
||||
|
||||
@@ -39,6 +39,9 @@ rtems_status_code rtems_clock_set(
|
||||
{
|
||||
rtems_interval seconds;
|
||||
|
||||
if ( !time_buffer )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( _TOD_Validate( time_buffer ) ) {
|
||||
seconds = _TOD_To_seconds( time_buffer );
|
||||
_Thread_Disable_dispatch();
|
||||
|
||||
@@ -52,6 +52,9 @@ rtems_status_code rtems_port_create(
|
||||
if ( !rtems_is_name_valid( name) )
|
||||
return RTEMS_INVALID_NAME;
|
||||
|
||||
if ( !id )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !_Addresses_Is_aligned( internal_start ) ||
|
||||
!_Addresses_Is_aligned( external_start ) )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
@@ -49,6 +49,9 @@ rtems_status_code rtems_port_external_to_internal(
|
||||
Objects_Locations location;
|
||||
unsigned32 ending;
|
||||
|
||||
if ( !internal )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_port = _Dual_ported_memory_Get( id, &location );
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE: /* this error cannot be returned */
|
||||
|
||||
@@ -49,6 +49,9 @@ rtems_status_code rtems_port_internal_to_external(
|
||||
Objects_Locations location;
|
||||
unsigned32 ending;
|
||||
|
||||
if ( !external )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_port = _Dual_ported_memory_Get( id, &location );
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE: /* this error cannot be returned */
|
||||
|
||||
@@ -48,6 +48,9 @@ rtems_status_code rtems_event_receive(
|
||||
{
|
||||
RTEMS_API_Control *api;
|
||||
|
||||
if ( !event_out )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
api = _Thread_Executing->API_Extensions[ THREAD_API_RTEMS ];
|
||||
|
||||
if ( _Event_sets_Is_empty( event_in ) ) {
|
||||
|
||||
@@ -60,6 +60,12 @@ rtems_status_code rtems_message_queue_broadcast(
|
||||
Objects_Locations location;
|
||||
CORE_message_queue_Status core_status;
|
||||
|
||||
if ( !buffer )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !count )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_message_queue = _Message_queue_Get( id, &location );
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE:
|
||||
|
||||
@@ -67,6 +67,9 @@ rtems_status_code rtems_message_queue_create(
|
||||
if ( !rtems_is_name_valid( name ) )
|
||||
return RTEMS_INVALID_NAME;
|
||||
|
||||
if ( !id )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
#if defined(RTEMS_MULTIPROCESSING)
|
||||
if ( (is_global = _Attributes_Is_global( attribute_set ) ) &&
|
||||
!_System_state_Is_multiprocessing )
|
||||
|
||||
@@ -56,6 +56,9 @@ rtems_status_code rtems_message_queue_flush(
|
||||
register Message_queue_Control *the_message_queue;
|
||||
Objects_Locations location;
|
||||
|
||||
if ( !count )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_message_queue = _Message_queue_Get( id, &location );
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE:
|
||||
|
||||
@@ -54,6 +54,9 @@ rtems_status_code rtems_message_queue_get_number_pending(
|
||||
register Message_queue_Control *the_message_queue;
|
||||
Objects_Locations location;
|
||||
|
||||
if ( !count )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_message_queue = _Message_queue_Get( id, &location );
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE:
|
||||
|
||||
@@ -61,6 +61,12 @@ rtems_status_code rtems_message_queue_receive(
|
||||
Objects_Locations location;
|
||||
boolean wait;
|
||||
|
||||
if ( !buffer )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !size )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_message_queue = _Message_queue_Get( id, &location );
|
||||
switch ( location ) {
|
||||
|
||||
|
||||
@@ -69,6 +69,9 @@ rtems_status_code _Message_queue_Submit(
|
||||
Objects_Locations location;
|
||||
CORE_message_queue_Status msg_status;
|
||||
|
||||
if ( !buffer )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_message_queue = _Message_queue_Get( id, &location );
|
||||
switch ( location )
|
||||
{
|
||||
|
||||
@@ -56,6 +56,12 @@ rtems_status_code rtems_partition_create(
|
||||
if ( !rtems_is_name_valid( name ) )
|
||||
return RTEMS_INVALID_NAME;
|
||||
|
||||
if ( !starting_address )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !id )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( length == 0 || buffer_size == 0 || length < buffer_size ||
|
||||
!_Partition_Is_buffer_size_aligned( buffer_size ) )
|
||||
return RTEMS_INVALID_SIZE;
|
||||
|
||||
@@ -46,6 +46,9 @@ rtems_status_code rtems_partition_get_buffer(
|
||||
Objects_Locations location;
|
||||
void *the_buffer;
|
||||
|
||||
if ( !buffer )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_partition = _Partition_Get( id, &location );
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE:
|
||||
|
||||
@@ -47,6 +47,9 @@ rtems_status_code rtems_rate_monotonic_create(
|
||||
if ( !rtems_is_name_valid( name ) )
|
||||
return RTEMS_INVALID_NAME;
|
||||
|
||||
if ( !id )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
_Thread_Disable_dispatch(); /* to prevent deletion */
|
||||
|
||||
the_period = _Rate_monotonic_Allocate();
|
||||
|
||||
@@ -45,7 +45,7 @@ rtems_status_code rtems_rate_monotonic_get_status(
|
||||
Objects_Locations location;
|
||||
Rate_monotonic_Control *the_period;
|
||||
|
||||
if ( status == NULL )
|
||||
if ( !status )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_period = _Rate_monotonic_Get( id, &location );
|
||||
|
||||
@@ -57,6 +57,12 @@ rtems_status_code rtems_region_create(
|
||||
if ( !rtems_is_name_valid( name ) )
|
||||
return RTEMS_INVALID_NAME;
|
||||
|
||||
if ( !starting_address )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !id )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !_Addresses_Is_aligned( starting_address ) )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
|
||||
@@ -51,6 +51,9 @@ rtems_status_code rtems_region_extend(
|
||||
Heap_Extend_status heap_status;
|
||||
rtems_status_code status;
|
||||
|
||||
if ( !starting_address )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
status = RTEMS_SUCCESSFUL;
|
||||
|
||||
_RTEMS_Lock_allocator(); /* to prevent deletion */
|
||||
|
||||
@@ -54,6 +54,9 @@ rtems_status_code rtems_region_get_segment(
|
||||
Thread_Control *executing;
|
||||
void *the_segment;
|
||||
|
||||
if ( !segment )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
*segment = NULL;
|
||||
|
||||
if ( size == 0 )
|
||||
|
||||
@@ -49,6 +49,12 @@ rtems_status_code rtems_region_get_segment_size(
|
||||
Objects_Locations location;
|
||||
Thread_Control *executing;
|
||||
|
||||
if ( !segment )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !size )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
_RTEMS_Lock_allocator();
|
||||
executing = _Thread_Executing;
|
||||
the_region = _Region_Get( id, &location );
|
||||
|
||||
@@ -81,6 +81,9 @@ rtems_status_code rtems_semaphore_create(
|
||||
if ( !rtems_is_name_valid( name ) )
|
||||
return RTEMS_INVALID_NAME;
|
||||
|
||||
if ( !id )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
#if defined(RTEMS_MULTIPROCESSING)
|
||||
if ( _Attributes_Is_global( attribute_set ) ) {
|
||||
|
||||
|
||||
@@ -75,6 +75,9 @@ rtems_status_code rtems_task_create(
|
||||
if ( !rtems_is_name_valid( name ) )
|
||||
return RTEMS_INVALID_NAME;
|
||||
|
||||
if ( !id )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
/*
|
||||
* Core Thread Initialize insures we get the minimum amount of
|
||||
* stack space.
|
||||
|
||||
@@ -56,6 +56,9 @@ rtems_status_code rtems_task_get_note(
|
||||
Objects_Locations location;
|
||||
RTEMS_API_Control *api;
|
||||
|
||||
if ( !note )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
/*
|
||||
* NOTE: There is no check for < RTEMS_NOTEPAD_FIRST because that would
|
||||
* be checking an unsigned number for being negative.
|
||||
|
||||
@@ -58,6 +58,9 @@ rtems_status_code rtems_task_mode(
|
||||
boolean needs_asr_dispatching = FALSE;
|
||||
rtems_mode old_mode;
|
||||
|
||||
if ( !previous_mode_set )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
executing = _Thread_Executing;
|
||||
api = executing->API_Extensions[ THREAD_API_RTEMS ];
|
||||
asr = &api->Signal;
|
||||
|
||||
@@ -32,6 +32,9 @@ rtems_status_code rtems_task_variable_add(
|
||||
Objects_Locations location;
|
||||
rtems_task_variable_t *tvp, *new;
|
||||
|
||||
if ( !ptr )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_thread = _Thread_Get (tid, &location);
|
||||
switch (location) {
|
||||
case OBJECTS_REMOTE:
|
||||
|
||||
@@ -31,6 +31,9 @@ rtems_status_code rtems_task_variable_delete(
|
||||
Objects_Locations location;
|
||||
rtems_task_variable_t *tvp, *prev;
|
||||
|
||||
if ( !ptr )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
prev = NULL;
|
||||
|
||||
the_thread = _Thread_Get (tid, &location);
|
||||
|
||||
@@ -32,6 +32,12 @@ rtems_status_code rtems_task_variable_get(
|
||||
Objects_Locations location;
|
||||
rtems_task_variable_t *tvp;
|
||||
|
||||
if ( !ptr )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !result )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_thread = _Thread_Get (tid, &location);
|
||||
switch (location) {
|
||||
case OBJECTS_REMOTE:
|
||||
|
||||
@@ -52,6 +52,9 @@ rtems_time_of_day *time_buffer
|
||||
if ( !_TOD_Is_set )
|
||||
return RTEMS_NOT_DEFINED;
|
||||
|
||||
if ( !time_buffer )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
time_buffer->ticks = 0;
|
||||
|
||||
if ( !_TOD_Validate( time_buffer ) )
|
||||
|
||||
@@ -47,6 +47,9 @@ rtems_status_code rtems_timer_create(
|
||||
if ( !rtems_is_name_valid( name ) )
|
||||
return RTEMS_INVALID_NAME;
|
||||
|
||||
if ( !id )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
_Thread_Disable_dispatch(); /* to prevent deletion */
|
||||
|
||||
the_timer = _Timer_Allocate();
|
||||
|
||||
@@ -51,6 +51,9 @@ rtems_status_code rtems_timer_fire_after(
|
||||
if ( ticks == 0 )
|
||||
return RTEMS_INVALID_NUMBER;
|
||||
|
||||
if ( !routine )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
the_timer = _Timer_Get( id, &location );
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE: /* should never return this */
|
||||
|
||||
@@ -55,6 +55,9 @@ rtems_status_code rtems_timer_fire_when(
|
||||
if ( !_TOD_Validate( wall_time ) )
|
||||
return RTEMS_INVALID_CLOCK;
|
||||
|
||||
if ( !routine )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
seconds = _TOD_To_seconds( wall_time );
|
||||
if ( seconds <= _TOD_Seconds_since_epoch )
|
||||
return RTEMS_INVALID_CLOCK;
|
||||
|
||||
@@ -53,6 +53,9 @@ rtems_status_code rtems_timer_server_fire_after(
|
||||
if ( !_Timer_Server )
|
||||
return RTEMS_INCORRECT_STATE;
|
||||
|
||||
if ( !routine )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( ticks == 0 )
|
||||
return RTEMS_INVALID_NUMBER;
|
||||
|
||||
|
||||
@@ -57,6 +57,9 @@ rtems_status_code rtems_timer_server_fire_when(
|
||||
if ( !_TOD_Is_set )
|
||||
return RTEMS_NOT_DEFINED;
|
||||
|
||||
if ( !routine )
|
||||
return RTEMS_INVALID_ADDRESS;
|
||||
|
||||
if ( !_TOD_Validate( wall_time ) )
|
||||
return RTEMS_INVALID_CLOCK;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user