fix time mould-kernel:fix 2 api clock_gettime、clock_getres

Change-Id: I260e47c895ced01e033ef8a824744e574887c9f5
This commit is contained in:
teamol 2021-05-14 15:10:30 +08:00
parent a53ad12907
commit e8427a45c5
3 changed files with 60 additions and 6 deletions

View File

@ -467,11 +467,9 @@ static int PthreadGetCputime(clockid_t clockID, struct timespec *ats)
return -EINVAL; return -EINVAL;
} }
#ifdef LOSCFG_KERNEL_CPUP
SCHEDULER_LOCK(intSave); SCHEDULER_LOCK(intSave);
runtime = task->taskCpup.allTime; runtime = task->taskCpup.allTime;
SCHEDULER_UNLOCK(intSave); SCHEDULER_UNLOCK(intSave);
#endif
ats->tv_sec = runtime / OS_SYS_NS_PER_SECOND; ats->tv_sec = runtime / OS_SYS_NS_PER_SECOND;
ats->tv_nsec = runtime % OS_SYS_NS_PER_SECOND; ats->tv_nsec = runtime % OS_SYS_NS_PER_SECOND;
@ -495,11 +493,9 @@ static int ProcessGetCputime(clockid_t clockID, struct timespec *ats)
return -EINVAL; return -EINVAL;
} }
#ifdef LOSCFG_KERNEL_CPUP
SCHEDULER_LOCK(intSave); SCHEDULER_LOCK(intSave);
runtime = spcb->processCpup.allTime; runtime = spcb->processCpup.allTime;
SCHEDULER_UNLOCK(intSave); SCHEDULER_UNLOCK(intSave);
#endif
ats->tv_sec = runtime / OS_SYS_NS_PER_SECOND; ats->tv_sec = runtime / OS_SYS_NS_PER_SECOND;
ats->tv_nsec = runtime % OS_SYS_NS_PER_SECOND; ats->tv_nsec = runtime % OS_SYS_NS_PER_SECOND;
@ -529,6 +525,7 @@ int clock_gettime(clockid_t clockID, struct timespec *tp)
UINT32 intSave; UINT32 intSave;
struct timespec64 tmp = {0}; struct timespec64 tmp = {0};
struct timespec64 hwTime = {0}; struct timespec64 hwTime = {0};
int ret;
if (clockID > MAX_CLOCKS) { if (clockID > MAX_CLOCKS) {
goto ERROUT; goto ERROUT;
@ -572,8 +569,12 @@ int clock_gettime(clockid_t clockID, struct timespec *tp)
TIME_RETURN(ENOTSUP); TIME_RETURN(ENOTSUP);
default: default:
{ {
int ret = GetCputime(clockID, tp); #ifdef LOSCFG_KERNEL_CPUP
ret = GetCputime(clockID, tp);
TIME_RETURN(-ret); TIME_RETURN(-ret);
#else
TIME_RETURN(EINVAL);
#endif
} }
} }
@ -606,6 +607,10 @@ static int CheckClock(const clockid_t clockID)
static int CpuClockGetres(const clockid_t clockID, struct timespec *tp) static int CpuClockGetres(const clockid_t clockID, struct timespec *tp)
{ {
if (clockID > 0) {
return -EINVAL;
}
int error = CheckClock(clockID); int error = CheckClock(clockID);
if (!error) { if (!error) {
error = ProcessGetCputime(clockID, tp); error = ProcessGetCputime(clockID, tp);
@ -616,6 +621,8 @@ static int CpuClockGetres(const clockid_t clockID, struct timespec *tp)
int clock_getres(clockid_t clockID, struct timespec *tp) int clock_getres(clockid_t clockID, struct timespec *tp)
{ {
int ret;
if (tp == NULL) { if (tp == NULL) {
TIME_RETURN(EINVAL); TIME_RETURN(EINVAL);
} }
@ -644,10 +651,14 @@ int clock_getres(clockid_t clockID, struct timespec *tp)
case CLOCK_TAI: case CLOCK_TAI:
TIME_RETURN(ENOTSUP); TIME_RETURN(ENOTSUP);
default: default:
#ifdef LOSCFG_KERNEL_CPUP
{ {
int ret = CpuClockGetres(clockID, tp); ret = CpuClockGetres(clockID, tp);
TIME_RETURN(-ret); TIME_RETURN(-ret);
} }
#else
TIME_RETURN(EINVAL);
#endif
} }
TIME_RETURN(0); TIME_RETURN(0);

View File

@ -327,6 +327,17 @@ HWTEST_F(PosixPthreadTest, ItPosixPthread022, TestSize.Level0)
ItPosixPthread022(); // pthread_cancel ItPosixPthread022(); // pthread_cancel
} }
/* *
* @tc.name: IT_POSIX_PTHREAD_203
* @tc.desc: function for pthread concurrency
* @tc.type: FUNC
* @tc.require: AR000EEMQ9
*/
HWTEST_F(PosixPthreadTest, ItPosixPthread203, TestSize.Level0)
{
ItPosixPthread203();
}
#endif #endif
#if defined(LOSCFG_USER_TEST_FULL) #if defined(LOSCFG_USER_TEST_FULL)

View File

@ -293,4 +293,36 @@ HWTEST_F(ProcessMutexTest, ItTestPthreadMutex022, TestSize.Level0)
ItTestPthreadMutex022(); ItTestPthreadMutex022();
} }
/* *
* @tc.name: it_test_pthread_mutex_023
* @tc.desc: function for test mutexattr robust
* @tc.type: FUNC
* @tc.require: AR000E0QAB
*/
HWTEST_F(ProcessMutexTest, ItTestPthreadMutex023, TestSize.Level0)
{
ItTestPthreadMutex023();
}
/* *
* @tc.name: it_test_pthread_mutex_024
* @tc.desc: function for test mutexattr robust:error return value
* @tc.type: FUNC
* @tc.require: AR000E0QAB
*/
HWTEST_F(ProcessMutexTest, ItTestPthreadMutex024, TestSize.Level0)
{
ItTestPthreadMutex024();
}
/* *
* @tc.name: it_test_pthread_mutex_025
* @tc.desc: test mutexattr robust:robustness product deadlock is not set
* @tc.type: FUNC
* @tc.require: AR000E0QAB
*/
HWTEST_F(ProcessMutexTest, ItTestPthreadMutex025, TestSize.Level0)
{
ItTestPthreadMutex025();
}
} // namespace OHOS } // namespace OHOS