Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Kernel Liteos A
提交
9018eab2
K
Kernel Liteos A
项目概览
OpenHarmony
/
Kernel Liteos A
1 年多 前同步成功
通知
463
Star
414
Fork
55
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
4
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel Liteos A
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
4
Issue
4
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
9018eab2
编写于
1月 19, 2022
作者:
O
openharmony_ci
提交者:
Gitee
1月 19, 2022
浏览文件
操作
浏览文件
下载
差异文件
!782 feat: 调度tick响应时间计算优化
Merge pull request !782 from zhushengle/calc_sched
上级
e6bdfbb7
f47da44b
变更
9
显示空白变更内容
内联
并排
Showing
9 changed file
with
108 addition
and
150 deletion
+108
-150
arch/arm/arm/include/hal_timer.h
arch/arm/arm/include/hal_timer.h
+1
-1
arch/arm/arm/src/arm_generic_timer.c
arch/arm/arm/src/arm_generic_timer.c
+2
-7
kernel/base/core/los_swtmr.c
kernel/base/core/los_swtmr.c
+29
-2
kernel/base/include/los_sched_pri.h
kernel/base/include/los_sched_pri.h
+1
-9
kernel/base/include/los_sortlink_pri.h
kernel/base/include/los_sortlink_pri.h
+24
-2
kernel/base/include/los_swtmr_pri.h
kernel/base/include/los_swtmr_pri.h
+1
-0
kernel/base/sched/sched_sq/los_sched.c
kernel/base/sched/sched_sq/los_sched.c
+45
-80
kernel/base/sched/sched_sq/los_sortlink.c
kernel/base/sched/sched_sq/los_sortlink.c
+4
-48
testsuites/unittest/process/basic/process/smoke/process_test_001.cpp
...unittest/process/basic/process/smoke/process_test_001.cpp
+1
-1
未找到文件。
arch/arm/arm/include/hal_timer.h
浏览文件 @
9018eab2
...
@@ -46,7 +46,7 @@ extern VOID HalClockInit(VOID);
...
@@ -46,7 +46,7 @@ extern VOID HalClockInit(VOID);
extern
UINT64
HalClockGetCycles
(
VOID
);
extern
UINT64
HalClockGetCycles
(
VOID
);
extern
VOID
HalDelayUs
(
UINT32
usecs
);
extern
VOID
HalDelayUs
(
UINT32
usecs
);
extern
UINT32
HalClockGetTickTimerCycles
(
VOID
);
extern
UINT32
HalClockGetTickTimerCycles
(
VOID
);
extern
VOID
HalClockTickTimerReload
(
UINT64
cycles
);
extern
UINT64
HalClockTickTimerReload
(
UINT64
cycles
);
extern
UINT32
HrtimersInit
(
VOID
);
extern
UINT32
HrtimersInit
(
VOID
);
extern
VOID
HrtimerClockIrqClear
(
VOID
);
extern
VOID
HrtimerClockIrqClear
(
VOID
);
...
...
arch/arm/arm/src/arm_generic_timer.c
浏览文件 @
9018eab2
...
@@ -31,7 +31,6 @@
...
@@ -31,7 +31,6 @@
#include "los_hw_pri.h"
#include "los_hw_pri.h"
#include "los_tick_pri.h"
#include "los_tick_pri.h"
#include "los_sched_pri.h"
#include "los_sys_pri.h"
#include "los_sys_pri.h"
#include "gic_common.h"
#include "gic_common.h"
...
@@ -139,11 +138,6 @@ LITE_OS_SEC_TEXT_INIT VOID HalClockInit(VOID)
...
@@ -139,11 +138,6 @@ LITE_OS_SEC_TEXT_INIT VOID HalClockInit(VOID)
LITE_OS_SEC_TEXT_INIT
VOID
HalClockStart
(
VOID
)
LITE_OS_SEC_TEXT_INIT
VOID
HalClockStart
(
VOID
)
{
{
UINT32
ret
=
OsSchedSetTickTimerType
(
64
);
/* 64 bit tick timer */
if
(
ret
!=
LOS_OK
)
{
return
;
}
HalIrqUnmask
(
OS_TICK_INT_NUM
);
HalIrqUnmask
(
OS_TICK_INT_NUM
);
/* triggle the first tick */
/* triggle the first tick */
...
@@ -175,7 +169,7 @@ UINT32 HalClockGetTickTimerCycles(VOID)
...
@@ -175,7 +169,7 @@ UINT32 HalClockGetTickTimerCycles(VOID)
return
(
UINT32
)((
cval
>
cycles
)
?
(
cval
-
cycles
)
:
0
);
return
(
UINT32
)((
cval
>
cycles
)
?
(
cval
-
cycles
)
:
0
);
}
}
VOID
HalClockTickTimerReload
(
UINT64
cycles
)
UINT64
HalClockTickTimerReload
(
UINT64
cycles
)
{
{
HalIrqMask
(
OS_TICK_INT_NUM
);
HalIrqMask
(
OS_TICK_INT_NUM
);
HalIrqClear
(
OS_TICK_INT_NUM
);
HalIrqClear
(
OS_TICK_INT_NUM
);
...
@@ -185,4 +179,5 @@ VOID HalClockTickTimerReload(UINT64 cycles)
...
@@ -185,4 +179,5 @@ VOID HalClockTickTimerReload(UINT64 cycles)
TimerCtlWrite
(
1
);
TimerCtlWrite
(
1
);
HalIrqUnmask
(
OS_TICK_INT_NUM
);
HalIrqUnmask
(
OS_TICK_INT_NUM
);
return
cycles
;
}
}
kernel/base/core/los_swtmr.c
浏览文件 @
9018eab2
...
@@ -246,7 +246,7 @@ STATIC INLINE VOID OsWakePendTimeSwtmr(Percpu *cpu, UINT64 currTime, SWTMR_CTRL_
...
@@ -246,7 +246,7 @@ STATIC INLINE VOID OsWakePendTimeSwtmr(Percpu *cpu, UINT64 currTime, SWTMR_CTRL_
LITE_OS_SEC_TEXT
VOID
OsSwtmrScan
(
VOID
)
LITE_OS_SEC_TEXT
VOID
OsSwtmrScan
(
VOID
)
{
{
Percpu
*
cpu
=
OsPercpuGet
();
Percpu
*
cpu
=
OsPercpuGet
();
SortLinkAttribute
*
swtmrSortLink
=
&
OsPercpuGet
()
->
swtmrSortLink
;
SortLinkAttribute
*
swtmrSortLink
=
&
cpu
->
swtmrSortLink
;
LOS_DL_LIST
*
listObject
=
&
swtmrSortLink
->
sortLink
;
LOS_DL_LIST
*
listObject
=
&
swtmrSortLink
->
sortLink
;
/*
/*
...
@@ -283,6 +283,33 @@ LITE_OS_SEC_TEXT VOID OsSwtmrScan(VOID)
...
@@ -283,6 +283,33 @@ LITE_OS_SEC_TEXT VOID OsSwtmrScan(VOID)
LOS_SpinUnlock
(
&
cpu
->
swtmrSortLinkSpin
);
LOS_SpinUnlock
(
&
cpu
->
swtmrSortLinkSpin
);
}
}
LITE_OS_SEC_TEXT
VOID
OsSwtmrResponseTimeReset
(
UINT64
startTime
)
{
UINT32
intSave
;
Percpu
*
cpu
=
OsPercpuGet
();
SortLinkAttribute
*
swtmrSortLink
=
&
cpu
->
swtmrSortLink
;
LOS_DL_LIST
*
listHead
=
&
swtmrSortLink
->
sortLink
;
LOS_DL_LIST
*
listNext
=
listHead
->
pstNext
;
LOS_SpinLock
(
&
cpu
->
swtmrSortLinkSpin
);
while
(
listNext
!=
listHead
)
{
SortLinkList
*
sortList
=
LOS_DL_LIST_ENTRY
(
listNext
,
SortLinkList
,
sortLinkNode
);
OsDeleteNodeSortLink
(
swtmrSortLink
,
sortList
);
LOS_SpinUnlock
(
&
cpu
->
swtmrSortLinkSpin
);
SWTMR_CTRL_S
*
swtmr
=
LOS_DL_LIST_ENTRY
(
sortList
,
SWTMR_CTRL_S
,
stSortList
);
SWTMR_LOCK
(
intSave
);
swtmr
->
startTime
=
startTime
;
OsSwtmrStart
(
startTime
,
swtmr
);
SWTMR_UNLOCK
(
intSave
);
LOS_SpinLock
(
&
cpu
->
swtmrSortLinkSpin
);
listNext
=
listNext
->
pstNext
;
}
LOS_SpinUnlock
(
&
cpu
->
swtmrSortLinkSpin
);
}
/*
/*
* Description: Get next timeout
* Description: Get next timeout
* Return : Count of the Timer list
* Return : Count of the Timer list
...
...
kernel/base/include/los_sched_pri.h
浏览文件 @
9018eab2
...
@@ -52,15 +52,9 @@ extern "C" {
...
@@ -52,15 +52,9 @@ extern "C" {
extern
UINT32
g_taskScheduled
;
extern
UINT32
g_taskScheduled
;
typedef
BOOL
(
*
SchedScan
)(
VOID
);
typedef
BOOL
(
*
SchedScan
)(
VOID
);
extern
UINT64
g_sysSchedStartTime
;
STATIC
INLINE
UINT64
OsGetCurrSchedTimeCycle
(
VOID
)
STATIC
INLINE
UINT64
OsGetCurrSchedTimeCycle
(
VOID
)
{
{
if
(
g_sysSchedStartTime
!=
OS_64BIT_MAX
)
{
return
HalClockGetCycles
();
return
(
HalClockGetCycles
()
-
g_sysSchedStartTime
);
}
return
0
;
}
}
STATIC
INLINE
VOID
OsSchedIrqUpdateUsedTime
(
VOID
)
STATIC
INLINE
VOID
OsSchedIrqUpdateUsedTime
(
VOID
)
...
@@ -156,8 +150,6 @@ STATIC INLINE VOID OsCpuSchedUnlock(Percpu *cpu, UINT32 intSave)
...
@@ -156,8 +150,6 @@ STATIC INLINE VOID OsCpuSchedUnlock(Percpu *cpu, UINT32 intSave)
LOS_IntRestore
(
intSave
);
LOS_IntRestore
(
intSave
);
}
}
extern
UINT32
OsSchedSetTickTimerType
(
UINT32
timerType
);
extern
VOID
OsSchedSetIdleTaskSchedParam
(
LosTaskCB
*
idleTask
);
extern
VOID
OsSchedSetIdleTaskSchedParam
(
LosTaskCB
*
idleTask
);
extern
UINT32
OsSchedSwtmrScanRegister
(
SchedScan
func
);
extern
UINT32
OsSchedSwtmrScanRegister
(
SchedScan
func
);
...
...
kernel/base/include/los_sortlink_pri.h
浏览文件 @
9018eab2
...
@@ -64,9 +64,31 @@ typedef struct {
...
@@ -64,9 +64,31 @@ typedef struct {
#define SET_SORTLIST_VALUE(sortList, value) (((SortLinkList *)(sortList))->responseTime = (value))
#define SET_SORTLIST_VALUE(sortList, value) (((SortLinkList *)(sortList))->responseTime = (value))
#define GET_SORTLIST_VALUE(sortList) (((SortLinkList *)(sortList))->responseTime)
#define GET_SORTLIST_VALUE(sortList) (((SortLinkList *)(sortList))->responseTime)
extern
UINT64
OsGetNextExpireTime
(
UINT64
startTime
);
STATIC
INLINE
VOID
OsDeleteNodeSortLink
(
SortLinkAttribute
*
sortLinkHeader
,
SortLinkList
*
sortList
)
{
LOS_ListDelete
(
&
sortList
->
sortLinkNode
);
SET_SORTLIST_VALUE
(
sortList
,
OS_SORT_LINK_INVALID_TIME
);
sortLinkHeader
->
nodeNum
--
;
}
STATIC
INLINE
UINT64
OsGetSortLinkNextExpireTime
(
SortLinkAttribute
*
sortHeader
,
UINT64
startTime
,
UINT32
tickPrecision
)
{
LOS_DL_LIST
*
head
=
&
sortHeader
->
sortLink
;
LOS_DL_LIST
*
list
=
head
->
pstNext
;
if
(
LOS_ListEmpty
(
head
))
{
return
OS_SORT_LINK_INVALID_TIME
-
tickPrecision
;
}
SortLinkList
*
listSorted
=
LOS_DL_LIST_ENTRY
(
list
,
SortLinkList
,
sortLinkNode
);
if
(
listSorted
->
responseTime
<=
(
startTime
+
tickPrecision
))
{
return
startTime
+
tickPrecision
;
}
return
listSorted
->
responseTime
;
}
extern
UINT32
OsSortLinkInit
(
SortLinkAttribute
*
sortLinkHeader
);
extern
UINT32
OsSortLinkInit
(
SortLinkAttribute
*
sortLinkHeader
);
extern
VOID
OsDeleteNodeSortLink
(
SortLinkAttribute
*
sortLinkHeader
,
SortLinkList
*
sortList
);
extern
VOID
OsAdd2SortLink
(
SortLinkList
*
node
,
UINT64
startTime
,
UINT32
waitTicks
,
SortLinkType
type
);
extern
VOID
OsAdd2SortLink
(
SortLinkList
*
node
,
UINT64
startTime
,
UINT32
waitTicks
,
SortLinkType
type
);
extern
VOID
OsDeleteSortLink
(
SortLinkList
*
node
,
SortLinkType
type
);
extern
VOID
OsDeleteSortLink
(
SortLinkList
*
node
,
SortLinkType
type
);
extern
UINT32
OsSortLinkGetTargetExpireTime
(
const
SortLinkList
*
targetSortList
);
extern
UINT32
OsSortLinkGetTargetExpireTime
(
const
SortLinkList
*
targetSortList
);
...
...
kernel/base/include/los_swtmr_pri.h
浏览文件 @
9018eab2
...
@@ -104,6 +104,7 @@ extern VOID OsSwtmrScan(VOID);
...
@@ -104,6 +104,7 @@ extern VOID OsSwtmrScan(VOID);
extern
UINT32
OsSwtmrInit
(
VOID
);
extern
UINT32
OsSwtmrInit
(
VOID
);
extern
VOID
OsSwtmrTask
(
VOID
);
extern
VOID
OsSwtmrTask
(
VOID
);
extern
VOID
OsSwtmrRecycle
(
UINT32
processID
);
extern
VOID
OsSwtmrRecycle
(
UINT32
processID
);
extern
VOID
OsSwtmrResponseTimeReset
(
UINT64
startTime
);
extern
SPIN_LOCK_S
g_swtmrSpin
;
extern
SPIN_LOCK_S
g_swtmrSpin
;
#ifdef __cplusplus
#ifdef __cplusplus
#if __cplusplus
#if __cplusplus
...
...
kernel/base/sched/sched_sq/los_sched.c
浏览文件 @
9018eab2
...
@@ -32,6 +32,7 @@
...
@@ -32,6 +32,7 @@
#include "los_sched_pri.h"
#include "los_sched_pri.h"
#include "los_hw_pri.h"
#include "los_hw_pri.h"
#include "los_task_pri.h"
#include "los_task_pri.h"
#include "los_swtmr_pri.h"
#include "los_process_pri.h"
#include "los_process_pri.h"
#include "los_arch_mmu.h"
#include "los_arch_mmu.h"
#include "los_hook.h"
#include "los_hook.h"
...
@@ -75,8 +76,6 @@ typedef struct {
...
@@ -75,8 +76,6 @@ typedef struct {
}
Sched
;
}
Sched
;
STATIC
Sched
*
g_sched
=
NULL
;
STATIC
Sched
*
g_sched
=
NULL
;
STATIC
UINT64
g_schedTickMaxResponseTime
;
UINT64
g_sysSchedStartTime
=
OS_64BIT_MAX
;
#ifdef LOSCFG_SCHED_TICK_DEBUG
#ifdef LOSCFG_SCHED_TICK_DEBUG
#define OS_SCHED_DEBUG_DATA_NUM 1000
#define OS_SCHED_DEBUG_DATA_NUM 1000
...
@@ -237,30 +236,6 @@ UINT32 OsShellShowSchedParam(VOID)
...
@@ -237,30 +236,6 @@ UINT32 OsShellShowSchedParam(VOID)
}
}
#endif
#endif
UINT32
OsSchedSetTickTimerType
(
UINT32
timerType
)
{
switch
(
timerType
)
{
case
32
:
/* 32 bit timer */
g_schedTickMaxResponseTime
=
OS_32BIT_MAX
;
break
;
case
64
:
/* 64 bit timer */
g_schedTickMaxResponseTime
=
OS_64BIT_MAX
;
break
;
default:
PRINT_ERR
(
"Unsupported Tick Timer type, The system only supports 32 and 64 bit tick timers
\n
"
);
return
LOS_NOK
;
}
return
LOS_OK
;
}
STATIC
VOID
OsSchedSetStartTime
(
UINT64
currCycle
)
{
if
(
g_sysSchedStartTime
==
OS_64BIT_MAX
)
{
g_sysSchedStartTime
=
currCycle
;
}
}
STATIC
INLINE
VOID
OsTimeSliceUpdate
(
LosTaskCB
*
taskCB
,
UINT64
currTime
)
STATIC
INLINE
VOID
OsTimeSliceUpdate
(
LosTaskCB
*
taskCB
,
UINT64
currTime
)
{
{
LOS_ASSERT
(
currTime
>=
taskCB
->
startTime
);
LOS_ASSERT
(
currTime
>=
taskCB
->
startTime
);
...
@@ -283,54 +258,29 @@ STATIC INLINE VOID OsTimeSliceUpdate(LosTaskCB *taskCB, UINT64 currTime)
...
@@ -283,54 +258,29 @@ STATIC INLINE VOID OsTimeSliceUpdate(LosTaskCB *taskCB, UINT64 currTime)
#endif
#endif
}
}
STATIC
INLINE
VOID
OsSchedTickReload
(
Percpu
*
currCpu
,
UINT64
nextResponseTime
,
UINT32
responseID
,
BOOL
isTimeSlice
)
STATIC
INLINE
UINT64
GetNextExpireTime
(
Percpu
*
cpu
,
UINT64
startTime
,
UINT32
tickPrecision
)
{
{
UINT64
currTime
,
nextExpireTime
;
SortLinkAttribute
*
taskHeader
=
&
cpu
->
taskSortLink
;
UINT32
usedTime
;
SortLinkAttribute
*
swtmrHeader
=
&
cpu
->
swtmrSortLink
;
currTime
=
OsGetCurrSchedTimeCycle
();
if
(
currCpu
->
tickStartTime
!=
0
)
{
usedTime
=
currTime
-
currCpu
->
tickStartTime
;
currCpu
->
tickStartTime
=
0
;
}
else
{
usedTime
=
0
;
}
if
((
nextResponseTime
>
usedTime
)
&&
((
nextResponseTime
-
usedTime
)
>
OS_TICK_RESPONSE_PRECISION
))
{
LOS_SpinLock
(
&
cpu
->
taskSortLinkSpin
);
nextResponseTime
-=
usedTime
;
UINT64
taskExpireTime
=
OsGetSortLinkNextExpireTime
(
taskHeader
,
startTime
,
tickPrecision
);
}
else
{
LOS_SpinUnlock
(
&
cpu
->
taskSortLinkSpin
);
nextResponseTime
=
OS_TICK_RESPONSE_PRECISION
;
}
nextExpireTime
=
currTime
+
nextResponseTime
;
LOS_SpinLock
(
&
cpu
->
swtmrSortLinkSpin
);
if
(
nextExpireTime
>=
currCpu
->
responseTime
)
{
UINT64
swtmrExpireTime
=
OsGetSortLinkNextExpireTime
(
swtmrHeader
,
startTime
,
tickPrecision
);
return
;
LOS_SpinUnlock
(
&
cpu
->
swtmrSortLinkSpin
);
}
if
(
isTimeSlice
)
{
return
(
taskExpireTime
<
swtmrExpireTime
)
?
taskExpireTime
:
swtmrExpireTime
;
/* The expiration time of the current system is the thread's slice expiration time */
currCpu
->
responseID
=
responseID
;
}
else
{
currCpu
->
responseID
=
OS_INVALID_VALUE
;
}
currCpu
->
responseTime
=
nextExpireTime
;
HalClockTickTimerReload
(
nextResponseTime
);
#ifdef LOSCFG_SCHED_TICK_DEBUG
SchedTickDebug
*
schedDebug
=
&
g_schedTickDebug
[
ArchCurrCpuid
()];
if
(
schedDebug
->
index
<
OS_SCHED_DEBUG_DATA_NUM
)
{
schedDebug
->
setTickCount
++
;
}
#endif
}
}
STATIC
INLINE
VOID
OsSchedSetNextExpireTime
(
UINT64
startTime
,
UINT32
responseID
,
STATIC
INLINE
VOID
OsSchedSetNextExpireTime
(
UINT64
startTime
,
UINT32
responseID
,
UINT64
taskEndTime
,
UINT32
oldResponseID
)
UINT64
taskEndTime
,
UINT32
oldResponseID
)
{
{
UINT64
nextExpireTime
=
OsGetNextExpireTime
(
startTime
);
Percpu
*
currCpu
=
OsPercpuGet
();
Percpu
*
currCpu
=
OsPercpuGet
();
UINT64
nextResponseTime
;
UINT64
nextResponseTime
=
0
;
BOOL
isTimeSlice
=
FALSE
;
BOOL
isTimeSlice
=
FALSE
;
UINT64
nextExpireTime
=
GetNextExpireTime
(
currCpu
,
startTime
,
OS_TICK_RESPONSE_PRECISION
);
currCpu
->
schedFlag
&=
~
INT_PEND_TICK
;
currCpu
->
schedFlag
&=
~
INT_PEND_TICK
;
if
(
currCpu
->
responseID
==
oldResponseID
)
{
if
(
currCpu
->
responseID
==
oldResponseID
)
{
...
@@ -346,19 +296,35 @@ STATIC INLINE VOID OsSchedSetNextExpireTime(UINT64 startTime, UINT32 responseID,
...
@@ -346,19 +296,35 @@ STATIC INLINE VOID OsSchedSetNextExpireTime(UINT64 startTime, UINT32 responseID,
isTimeSlice
=
TRUE
;
isTimeSlice
=
TRUE
;
}
}
if
((
currCpu
->
responseTime
>
nextExpireTime
)
&&
if
((
currCpu
->
responseTime
<=
nextExpireTime
)
||
((
currCpu
->
responseTime
-
nextExpireTime
)
>=
OS_TICK_RESPONSE_PRECISION
))
{
((
currCpu
->
responseTime
-
nextExpireTime
)
<
OS_TICK_RESPONSE_PRECISION
))
{
nextResponseTime
=
nextExpireTime
-
startTime
;
return
;
if
(
nextResponseTime
>
g_schedTickMaxResponseTime
)
{
nextResponseTime
=
g_schedTickMaxResponseTime
;
}
}
UINT64
currTime
=
OsGetCurrSchedTimeCycle
();
if
(
nextExpireTime
>=
currTime
)
{
nextResponseTime
=
nextExpireTime
-
currTime
;
}
if
(
nextResponseTime
<
OS_TICK_RESPONSE_PRECISION
)
{
nextResponseTime
=
OS_TICK_RESPONSE_PRECISION
;
}
if
(
isTimeSlice
)
{
/* The expiration time of the current system is the thread's slice expiration time */
currCpu
->
responseID
=
responseID
;
}
else
{
}
else
{
/* There is no point earlier than the current expiration date */
currCpu
->
responseID
=
OS_INVALID_VALUE
;
currCpu
->
tickStartTime
=
0
;
return
;
}
}
OsSchedTickReload
(
currCpu
,
nextResponseTime
,
responseID
,
isTimeSlice
);
currCpu
->
responseTime
=
currTime
+
HalClockTickTimerReload
(
nextResponseTime
);
#ifdef LOSCFG_SCHED_TICK_DEBUG
SchedTickDebug
*
schedDebug
=
&
g_schedTickDebug
[
ArchCurrCpuid
()];
if
(
schedDebug
->
index
<
OS_SCHED_DEBUG_DATA_NUM
)
{
schedDebug
->
setTickCount
++
;
}
#endif
}
}
VOID
OsSchedUpdateExpireTime
(
UINT64
startTime
)
VOID
OsSchedUpdateExpireTime
(
UINT64
startTime
)
...
@@ -843,9 +809,7 @@ VOID OsSchedTick(VOID)
...
@@ -843,9 +809,7 @@ VOID OsSchedTick(VOID)
Sched
*
sched
=
g_sched
;
Sched
*
sched
=
g_sched
;
Percpu
*
currCpu
=
OsPercpuGet
();
Percpu
*
currCpu
=
OsPercpuGet
();
BOOL
needSched
=
FALSE
;
BOOL
needSched
=
FALSE
;
LosTaskCB
*
runTask
=
OsCurrTaskGet
();
currCpu
->
tickStartTime
=
runTask
->
irqStartTime
;
if
(
currCpu
->
responseID
==
OS_INVALID_VALUE
)
{
if
(
currCpu
->
responseID
==
OS_INVALID_VALUE
)
{
if
(
sched
->
swtmrScan
!=
NULL
)
{
if
(
sched
->
swtmrScan
!=
NULL
)
{
(
VOID
)
sched
->
swtmrScan
();
(
VOID
)
sched
->
swtmrScan
();
...
@@ -970,6 +934,8 @@ VOID OsSchedStart(VOID)
...
@@ -970,6 +934,8 @@ VOID OsSchedStart(VOID)
UINT32
cpuid
=
ArchCurrCpuid
();
UINT32
cpuid
=
ArchCurrCpuid
();
UINT32
intSave
;
UINT32
intSave
;
PRINTK
(
"cpu %d entering scheduler
\n
"
,
cpuid
);
SCHEDULER_LOCK
(
intSave
);
SCHEDULER_LOCK
(
intSave
);
if
(
cpuid
==
0
)
{
if
(
cpuid
==
0
)
{
...
@@ -983,9 +949,6 @@ VOID OsSchedStart(VOID)
...
@@ -983,9 +949,6 @@ VOID OsSchedStart(VOID)
newProcess
->
processStatus
|=
OS_PROCESS_STATUS_RUNNING
;
newProcess
->
processStatus
|=
OS_PROCESS_STATUS_RUNNING
;
newProcess
->
processStatus
=
OS_PROCESS_RUNTASK_COUNT_ADD
(
newProcess
->
processStatus
);
newProcess
->
processStatus
=
OS_PROCESS_RUNTASK_COUNT_ADD
(
newProcess
->
processStatus
);
OsSchedSetStartTime
(
HalClockGetCycles
());
newTask
->
startTime
=
OsGetCurrSchedTimeCycle
();
#ifdef LOSCFG_KERNEL_SMP
#ifdef LOSCFG_KERNEL_SMP
/*
/*
* attention: current cpu needs to be set, in case first task deletion
* attention: current cpu needs to be set, in case first task deletion
...
@@ -996,13 +959,15 @@ VOID OsSchedStart(VOID)
...
@@ -996,13 +959,15 @@ VOID OsSchedStart(VOID)
OsCurrTaskSet
((
VOID
*
)
newTask
);
OsCurrTaskSet
((
VOID
*
)
newTask
);
newTask
->
startTime
=
OsGetCurrSchedTimeCycle
();
OsSwtmrResponseTimeReset
(
newTask
->
startTime
);
/* System start schedule */
/* System start schedule */
OS_SCHEDULER_SET
(
cpuid
);
OS_SCHEDULER_SET
(
cpuid
);
OsPercpuGet
()
->
responseID
=
OS_INVALID
;
OsPercpuGet
()
->
responseID
=
OS_INVALID
;
OsSchedSetNextExpireTime
(
newTask
->
startTime
,
newTask
->
taskID
,
newTask
->
startTime
+
newTask
->
timeSlice
,
OS_INVALID
);
OsSchedSetNextExpireTime
(
newTask
->
startTime
,
newTask
->
taskID
,
newTask
->
startTime
+
newTask
->
timeSlice
,
OS_INVALID
);
PRINTK
(
"cpu %d entering scheduler
\n
"
,
cpuid
);
OsTaskContextLoad
(
newTask
);
OsTaskContextLoad
(
newTask
);
}
}
...
...
kernel/base/sched/sched_sq/los_sortlink.c
浏览文件 @
9018eab2
...
@@ -77,30 +77,6 @@ STATIC INLINE VOID OsAddNode2SortLink(SortLinkAttribute *sortLinkHeader, SortLin
...
@@ -77,30 +77,6 @@ STATIC INLINE VOID OsAddNode2SortLink(SortLinkAttribute *sortLinkHeader, SortLin
}
while
(
1
);
}
while
(
1
);
}
}
VOID
OsDeleteNodeSortLink
(
SortLinkAttribute
*
sortLinkHeader
,
SortLinkList
*
sortList
)
{
LOS_ListDelete
(
&
sortList
->
sortLinkNode
);
SET_SORTLIST_VALUE
(
sortList
,
OS_SORT_LINK_INVALID_TIME
);
sortLinkHeader
->
nodeNum
--
;
}
STATIC
INLINE
UINT64
OsGetSortLinkNextExpireTime
(
SortLinkAttribute
*
sortHeader
,
UINT64
startTime
)
{
LOS_DL_LIST
*
head
=
&
sortHeader
->
sortLink
;
LOS_DL_LIST
*
list
=
head
->
pstNext
;
if
(
LOS_ListEmpty
(
head
))
{
return
OS_SCHED_MAX_RESPONSE_TIME
-
OS_TICK_RESPONSE_PRECISION
;
}
SortLinkList
*
listSorted
=
LOS_DL_LIST_ENTRY
(
list
,
SortLinkList
,
sortLinkNode
);
if
(
listSorted
->
responseTime
<=
(
startTime
+
OS_TICK_RESPONSE_PRECISION
))
{
return
startTime
+
OS_TICK_RESPONSE_PRECISION
;
}
return
listSorted
->
responseTime
;
}
STATIC
Percpu
*
OsFindIdleCpu
(
UINT16
*
idleCpuID
)
STATIC
Percpu
*
OsFindIdleCpu
(
UINT16
*
idleCpuID
)
{
{
Percpu
*
idleCpu
=
OsPercpuGetByID
(
0
);
Percpu
*
idleCpu
=
OsPercpuGetByID
(
0
);
...
@@ -127,7 +103,6 @@ STATIC Percpu *OsFindIdleCpu(UINT16 *idleCpuID)
...
@@ -127,7 +103,6 @@ STATIC Percpu *OsFindIdleCpu(UINT16 *idleCpuID)
VOID
OsAdd2SortLink
(
SortLinkList
*
node
,
UINT64
startTime
,
UINT32
waitTicks
,
SortLinkType
type
)
VOID
OsAdd2SortLink
(
SortLinkList
*
node
,
UINT64
startTime
,
UINT32
waitTicks
,
SortLinkType
type
)
{
{
UINT32
intSave
;
Percpu
*
cpu
=
NULL
;
Percpu
*
cpu
=
NULL
;
SortLinkAttribute
*
sortLinkHeader
=
NULL
;
SortLinkAttribute
*
sortLinkHeader
=
NULL
;
SPIN_LOCK_S
*
spinLock
=
NULL
;
SPIN_LOCK_S
*
spinLock
=
NULL
;
...
@@ -150,7 +125,7 @@ VOID OsAdd2SortLink(SortLinkList *node, UINT64 startTime, UINT32 waitTicks, Sort
...
@@ -150,7 +125,7 @@ VOID OsAdd2SortLink(SortLinkList *node, UINT64 startTime, UINT32 waitTicks, Sort
LOS_Panic
(
"Sort link type error : %u
\n
"
,
type
);
LOS_Panic
(
"Sort link type error : %u
\n
"
,
type
);
}
}
LOS_SpinLock
Save
(
spinLock
,
&
intSave
);
LOS_SpinLock
(
spinLock
);
SET_SORTLIST_VALUE
(
node
,
startTime
+
(
UINT64
)
waitTicks
*
OS_CYCLE_PER_TICK
);
SET_SORTLIST_VALUE
(
node
,
startTime
+
(
UINT64
)
waitTicks
*
OS_CYCLE_PER_TICK
);
OsAddNode2SortLink
(
sortLinkHeader
,
node
);
OsAddNode2SortLink
(
sortLinkHeader
,
node
);
#ifdef LOSCFG_KERNEL_SMP
#ifdef LOSCFG_KERNEL_SMP
...
@@ -159,12 +134,11 @@ VOID OsAdd2SortLink(SortLinkList *node, UINT64 startTime, UINT32 waitTicks, Sort
...
@@ -159,12 +134,11 @@ VOID OsAdd2SortLink(SortLinkList *node, UINT64 startTime, UINT32 waitTicks, Sort
LOS_MpSchedule
(
CPUID_TO_AFFI_MASK
(
idleCpu
));
LOS_MpSchedule
(
CPUID_TO_AFFI_MASK
(
idleCpu
));
}
}
#endif
#endif
LOS_SpinUnlock
Restore
(
spinLock
,
intSave
);
LOS_SpinUnlock
(
spinLock
);
}
}
VOID
OsDeleteSortLink
(
SortLinkList
*
node
,
SortLinkType
type
)
VOID
OsDeleteSortLink
(
SortLinkList
*
node
,
SortLinkType
type
)
{
{
UINT32
intSave
;
#ifdef LOSCFG_KERNEL_SMP
#ifdef LOSCFG_KERNEL_SMP
Percpu
*
cpu
=
OsPercpuGetByID
(
node
->
cpuid
);
Percpu
*
cpu
=
OsPercpuGetByID
(
node
->
cpuid
);
#else
#else
...
@@ -183,29 +157,11 @@ VOID OsDeleteSortLink(SortLinkList *node, SortLinkType type)
...
@@ -183,29 +157,11 @@ VOID OsDeleteSortLink(SortLinkList *node, SortLinkType type)
LOS_Panic
(
"Sort link type error : %u
\n
"
,
type
);
LOS_Panic
(
"Sort link type error : %u
\n
"
,
type
);
}
}
LOS_SpinLock
Save
(
spinLock
,
&
intSave
);
LOS_SpinLock
(
spinLock
);
if
(
node
->
responseTime
!=
OS_SORT_LINK_INVALID_TIME
)
{
if
(
node
->
responseTime
!=
OS_SORT_LINK_INVALID_TIME
)
{
OsDeleteNodeSortLink
(
sortLinkHeader
,
node
);
OsDeleteNodeSortLink
(
sortLinkHeader
,
node
);
}
}
LOS_SpinUnlockRestore
(
spinLock
,
intSave
);
LOS_SpinUnlock
(
spinLock
);
}
UINT64
OsGetNextExpireTime
(
UINT64
startTime
)
{
UINT32
intSave
;
Percpu
*
cpu
=
OsPercpuGet
();
SortLinkAttribute
*
taskHeader
=
&
cpu
->
taskSortLink
;
SortLinkAttribute
*
swtmrHeader
=
&
cpu
->
swtmrSortLink
;
LOS_SpinLockSave
(
&
cpu
->
taskSortLinkSpin
,
&
intSave
);
UINT64
taskExpirTime
=
OsGetSortLinkNextExpireTime
(
taskHeader
,
startTime
);
LOS_SpinUnlockRestore
(
&
cpu
->
taskSortLinkSpin
,
intSave
);
LOS_SpinLockSave
(
&
cpu
->
swtmrSortLinkSpin
,
&
intSave
);
UINT64
swtmrExpirTime
=
OsGetSortLinkNextExpireTime
(
swtmrHeader
,
startTime
);
LOS_SpinUnlockRestore
(
&
cpu
->
swtmrSortLinkSpin
,
intSave
);
return
(
taskExpirTime
<
swtmrExpirTime
)
?
taskExpirTime
:
swtmrExpirTime
;
}
}
UINT32
OsSortLinkGetTargetExpireTime
(
const
SortLinkList
*
targetSortList
)
UINT32
OsSortLinkGetTargetExpireTime
(
const
SortLinkList
*
targetSortList
)
...
...
testsuites/unittest/process/basic/process/smoke/process_test_001.cpp
浏览文件 @
9018eab2
...
@@ -67,7 +67,7 @@ static int Testcase(VOID)
...
@@ -67,7 +67,7 @@ static int Testcase(VOID)
ICUNIT_ASSERT_EQUAL
(
err
,
EINVAL
,
err
);
ICUNIT_ASSERT_EQUAL
(
err
,
EINVAL
,
err
);
param
.
sched_priority
=
15
;
// 15, set pthread priority.
param
.
sched_priority
=
15
;
// 15, set pthread priority.
ret
=
sched_setparam
(
20
,
&
param
);
// 2
0, set the param.
ret
=
sched_setparam
(
60
,
&
param
);
// 6
0, set the param.
err
=
errno
;
err
=
errno
;
ICUNIT_ASSERT_EQUAL
(
ret
,
-
1
,
ret
);
ICUNIT_ASSERT_EQUAL
(
ret
,
-
1
,
ret
);
ICUNIT_ASSERT_EQUAL
(
err
,
ESRCH
,
err
);
ICUNIT_ASSERT_EQUAL
(
err
,
ESRCH
,
err
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录