mirror of
https://gitlab.rtems.org/rtems/rtos/rtems.git
synced 2025-12-05 15:15:44 +00:00
+ Modified correct return path to call _ITRON_return_errorno( E_OK ) instead
of enabling dispatching and returning E_OK. + Changed validation of the_thread to validation of location. + Set correct error code when dormant state. + Fixed comment.
This commit is contained in:
@@ -30,39 +30,34 @@ ER chg_pri(
|
||||
Priority_Control new_priority;
|
||||
|
||||
the_thread = _ITRON_Task_Get( tskid, &location );
|
||||
if (!the_thread)
|
||||
_ITRON_return_errorno( _ITRON_Task_Clarify_get_id_error( tskid ) );
|
||||
|
||||
if (_States_Is_dormant( the_thread->current_state ))
|
||||
return -1;
|
||||
|
||||
if (( tskpri <= 0 ) || ( tskpri >= 256 ))
|
||||
_ITRON_return_errorno( E_PAR );
|
||||
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE:
|
||||
case OBJECTS_ERROR:
|
||||
_ITRON_return_errorno( _ITRON_Task_Clarify_get_id_error( tskid ));
|
||||
|
||||
case OBJECTS_LOCAL:
|
||||
if (_States_Is_dormant( the_thread->current_state ))
|
||||
_ITRON_return_errorno( E_OBJ );
|
||||
|
||||
if (( tskpri <= 0 ) || ( tskpri >= 256 ))
|
||||
_ITRON_return_errorno( E_PAR );
|
||||
|
||||
new_priority = _ITRON_Task_Priority_to_Core( tskpri );
|
||||
the_thread->real_priority = new_priority;
|
||||
|
||||
/*
|
||||
* XXX This is from the rtems side and I'm not sure what this is for.
|
||||
* XXX Is this check right or should change priority be called
|
||||
* regardless?
|
||||
* The priority should not be changed until later if priority
|
||||
* inheratance has occured.
|
||||
*/
|
||||
|
||||
if ( the_thread->resource_count == 0 ||
|
||||
the_thread->current_priority > new_priority )
|
||||
_Thread_Change_priority( the_thread, new_priority, FALSE );
|
||||
|
||||
_Thread_Enable_dispatch();
|
||||
return E_OK;
|
||||
_ITRON_return_errorno( E_OK );
|
||||
}
|
||||
|
||||
return E_OBJ; /* XXX - Should never get here */
|
||||
_ITRON_return_errorno( E_OBJ ); /* XXX - Should never get here */
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -30,39 +30,34 @@ ER chg_pri(
|
||||
Priority_Control new_priority;
|
||||
|
||||
the_thread = _ITRON_Task_Get( tskid, &location );
|
||||
if (!the_thread)
|
||||
_ITRON_return_errorno( _ITRON_Task_Clarify_get_id_error( tskid ) );
|
||||
|
||||
if (_States_Is_dormant( the_thread->current_state ))
|
||||
return -1;
|
||||
|
||||
if (( tskpri <= 0 ) || ( tskpri >= 256 ))
|
||||
_ITRON_return_errorno( E_PAR );
|
||||
|
||||
switch ( location ) {
|
||||
case OBJECTS_REMOTE:
|
||||
case OBJECTS_ERROR:
|
||||
_ITRON_return_errorno( _ITRON_Task_Clarify_get_id_error( tskid ));
|
||||
|
||||
case OBJECTS_LOCAL:
|
||||
if (_States_Is_dormant( the_thread->current_state ))
|
||||
_ITRON_return_errorno( E_OBJ );
|
||||
|
||||
if (( tskpri <= 0 ) || ( tskpri >= 256 ))
|
||||
_ITRON_return_errorno( E_PAR );
|
||||
|
||||
new_priority = _ITRON_Task_Priority_to_Core( tskpri );
|
||||
the_thread->real_priority = new_priority;
|
||||
|
||||
/*
|
||||
* XXX This is from the rtems side and I'm not sure what this is for.
|
||||
* XXX Is this check right or should change priority be called
|
||||
* regardless?
|
||||
* The priority should not be changed until later if priority
|
||||
* inheratance has occured.
|
||||
*/
|
||||
|
||||
if ( the_thread->resource_count == 0 ||
|
||||
the_thread->current_priority > new_priority )
|
||||
_Thread_Change_priority( the_thread, new_priority, FALSE );
|
||||
|
||||
_Thread_Enable_dispatch();
|
||||
return E_OK;
|
||||
_ITRON_return_errorno( E_OK );
|
||||
}
|
||||
|
||||
return E_OBJ; /* XXX - Should never get here */
|
||||
_ITRON_return_errorno( E_OBJ ); /* XXX - Should never get here */
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user