These 2 patches look good to me.
On Mon, Apr 13, 2020 at 11:51 AM Sebastian Huber <sebastian.hu...@embedded-brains.de> wrote: > > Close #3949. > --- > cpukit/posix/src/clocksettime.c | 3 --- > cpukit/score/src/coretodset.c | 21 ++++++++++++++++++++- > testsuites/psxtests/psxclock/init.c | 25 +++++++++++++++++++++++++ > 3 files changed, 45 insertions(+), 4 deletions(-) > > diff --git a/cpukit/posix/src/clocksettime.c b/cpukit/posix/src/clocksettime.c > index 5bb6f2f14b..49e4761875 100644 > --- a/cpukit/posix/src/clocksettime.c > +++ b/cpukit/posix/src/clocksettime.c > @@ -40,9 +40,6 @@ int clock_settime( > if ( clock_id == CLOCK_REALTIME ) { > ISR_lock_Context lock_context; > > - if ( tp->tv_sec < TOD_SECONDS_1970_THROUGH_1988 ) > - rtems_set_errno_and_return_minus_one( EINVAL ); > - > _TOD_Lock(); > _TOD_Acquire( &lock_context ); > status = _TOD_Set( tp, &lock_context ); > diff --git a/cpukit/score/src/coretodset.c b/cpukit/score/src/coretodset.c > index ed840ece2b..b9a745d9b4 100644 > --- a/cpukit/score/src/coretodset.c > +++ b/cpukit/score/src/coretodset.c > @@ -22,6 +22,25 @@ > #include <rtems/score/assert.h> > #include <rtems/score/watchdogimpl.h> > > +static Status_Control _TOD_Check_time_of_day_and_run_hooks( > + const struct timespec *tod > +) > +{ > + if ( !_Watchdog_Is_valid_timespec( tod ) ) { > + return STATUS_INVALID_NUMBER; > + } > + > + if ( tod->tv_sec < TOD_SECONDS_1970_THROUGH_1988 ) { > + return STATUS_INVALID_NUMBER; > + } > + > + if ( _Watchdog_Is_far_future_timespec( tod ) ) { > + return STATUS_INVALID_NUMBER; > + } > + > + return _TOD_Hook_Run( TOD_ACTION_SET_CLOCK, tod ); > +} > + > Status_Control _TOD_Set( > const struct timespec *tod, > ISR_lock_Context *lock_context > @@ -35,7 +54,7 @@ Status_Control _TOD_Set( > > _Assert( _TOD_Is_owner() ); > > - status = _TOD_Hook_Run( TOD_ACTION_SET_CLOCK, tod ); > + status = _TOD_Check_time_of_day_and_run_hooks( tod ); > if ( status != STATUS_SUCCESSFUL ) { > _TOD_Release( lock_context ); > return status; > diff --git a/testsuites/psxtests/psxclock/init.c > b/testsuites/psxtests/psxclock/init.c > index 40c224cec4..778637b4fd 100644 > --- a/testsuites/psxtests/psxclock/init.c > +++ b/testsuites/psxtests/psxclock/init.c > @@ -96,16 +96,19 @@ static rtems_task Init( > /* error cases in clock_gettime and clock_settime */ > > puts( "Init: clock_gettime - EINVAL (NULL timespec)" ); > + errno = 0; > sc = clock_gettime( CLOCK_REALTIME, NULL ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > > puts( "Init: clock_gettime - EINVAL (invalid clockid)" ); > + errno = 0; > sc = clock_gettime( (clockid_t)-1, &tv ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > > puts( "Init: clock_settime - EINVAL (invalid clockid)" ); > + errno = 0; > sc = clock_settime( (clockid_t)-1, &tv ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > @@ -115,6 +118,23 @@ static rtems_task Init( > tv.tv_nsec = 0; > printf( ctime( &tv.tv_sec ) ); > puts( "Init: clock_settime - before 1988 EINVAL" ); > + errno = 0; > + sc = clock_settime( CLOCK_REALTIME, &tv ); > + rtems_test_assert( sc == -1 ); > + rtems_test_assert( errno == EINVAL ); > + > + puts( "Init: clock_settime - invalid nanoseconds EINVAL" ); > + tv.tv_sec = 946681200; > + tv.tv_nsec = 2000000000; > + errno = 0; > + sc = clock_settime( CLOCK_REALTIME, &tv ); > + rtems_test_assert( sc == -1 ); > + rtems_test_assert( errno == EINVAL ); > + > + puts( "Init: clock_settime - far future EINVAL" ); > + tv.tv_sec = 17179869184; > + tv.tv_nsec = 0; > + errno = 0; > sc = clock_settime( CLOCK_REALTIME, &tv ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > @@ -122,11 +142,13 @@ static rtems_task Init( > /* exercise clock_getres */ > > puts( "Init: clock_getres - EINVAL (invalid clockid)" ); > + errno = 0; > sc = clock_getres( (clockid_t) -1, &tv ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > > puts( "Init: clock_getres - EINVAL (NULL resolution)" ); > + errno = 0; > sc = clock_getres( CLOCK_REALTIME, NULL ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > @@ -196,6 +218,7 @@ static rtems_task Init( > tv.tv_sec = 0; > tv.tv_nsec = TOD_NANOSECONDS_PER_SECOND * 2; > puts( "Init: nanosleep - EINVAL (too many nanoseconds)" ); > + errno = 0; > sc = nanosleep ( &tv, &tr ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > @@ -204,6 +227,7 @@ static rtems_task Init( > tv.tv_sec = -1; > tv.tv_nsec = 0; > puts( "Init: nanosleep - negative seconds - EINVAL" ); > + errno = 0; > sc = nanosleep ( &tv, &tr ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > @@ -212,6 +236,7 @@ static rtems_task Init( > tv.tv_sec = 0; > tv.tv_nsec = -1; > puts( "Init: nanosleep - negative nanoseconds - EINVAL" ); > + errno = 0; > sc = nanosleep ( &tv, &tr ); > rtems_test_assert( sc == -1 ); > rtems_test_assert( errno == EINVAL ); > -- > 2.16.4 > > _______________________________________________ > devel mailing list > devel@rtems.org > http://lists.rtems.org/mailman/listinfo/devel _______________________________________________ devel mailing list devel@rtems.org http://lists.rtems.org/mailman/listinfo/devel