Compare commits
2 Commits
OpenHarmon
...
master
Author | SHA1 | Date |
---|---|---|
|
3d8536b450 | |
|
413b08295d |
|
@ -110,6 +110,12 @@ typedef struct {
|
||||||
*/
|
*/
|
||||||
#define OS_RISCV_VECTOR_CNT (OS_RISCV_SYS_VECTOR_CNT + OS_RISCV_CUSTOM_IRQ_VECTOR_CNT)
|
#define OS_RISCV_VECTOR_CNT (OS_RISCV_SYS_VECTOR_CNT + OS_RISCV_CUSTOM_IRQ_VECTOR_CNT)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ingroup los_arch_interrupt
|
||||||
|
* Count of risc-v system interrupt vector.
|
||||||
|
*/
|
||||||
|
#define OS_SYS_VECTOR_CNT 0
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Maximum number of supported hardware devices that generate hardware interrupts.
|
* Maximum number of supported hardware devices that generate hardware interrupts.
|
||||||
* The maximum number of hardware devices that generate hardware interrupts supported by hi3518ev200 is 32.
|
* The maximum number of hardware devices that generate hardware interrupts supported by hi3518ev200 is 32.
|
||||||
|
|
|
@ -616,11 +616,11 @@ LITE_OS_SEC_TEXT_MINOR UINT32 LOS_CpupUsageMonitor(CPUP_TYPE_E type, CPUP_MODE_E
|
||||||
#if (LOSCFG_CPUP_INCLUDE_IRQ == 1)
|
#if (LOSCFG_CPUP_INCLUDE_IRQ == 1)
|
||||||
LITE_OS_SEC_TEXT_MINOR VOID OsCpupIrqStart(UINT32 intNum)
|
LITE_OS_SEC_TEXT_MINOR VOID OsCpupIrqStart(UINT32 intNum)
|
||||||
{
|
{
|
||||||
if (g_irqCpupInitFlg == 0) {
|
if ((g_irqCpupInitFlg == 0) || (intNum < OS_SYS_VECTOR_CNT)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
UINT32 cpupIntNum = intNum - OS_SYS_VECTOR_CNT;
|
||||||
g_irqCpup[intNum].startTime = CpupTimeUsGet();
|
g_irqCpup[cpupIntNum].startTime = CpupTimeUsGet();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -629,33 +629,34 @@ LITE_OS_SEC_TEXT_MINOR VOID OsCpupIrqEnd(UINT32 intNum)
|
||||||
UINT64 cpuTime;
|
UINT64 cpuTime;
|
||||||
UINT64 usedTime;
|
UINT64 usedTime;
|
||||||
|
|
||||||
if (g_irqCpupInitFlg == 0) {
|
if ((g_irqCpupInitFlg == 0) || (intNum < OS_SYS_VECTOR_CNT)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_irqCpup[intNum].startTime == 0) {
|
UINT32 cpupIntNum = intNum - OS_SYS_VECTOR_CNT;
|
||||||
|
if (g_irqCpup[cpupIntNum].startTime == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
cpuTime = CpupTimeUsGet();
|
cpuTime = CpupTimeUsGet();
|
||||||
if (cpuTime < g_irqCpup[intNum].startTime) {
|
if (cpuTime < g_irqCpup[cpupIntNum].startTime) {
|
||||||
cpuTime += OS_US_PER_TICK;
|
cpuTime += OS_US_PER_TICK;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_irqCpup[intNum].cpupID = intNum;
|
g_irqCpup[cpupIntNum].cpupID = intNum;
|
||||||
g_irqCpup[intNum].status = OS_CPUP_USED;
|
g_irqCpup[cpupIntNum].status = OS_CPUP_USED;
|
||||||
usedTime = cpuTime - g_irqCpup[intNum].startTime;
|
usedTime = cpuTime - g_irqCpup[cpupIntNum].startTime;
|
||||||
|
|
||||||
if (g_irqCpup[intNum].count <= 1000) { /* 1000, Take 1000 samples */
|
if (g_irqCpup[cpupIntNum].count <= 1000) { /* 1000, Take 1000 samples */
|
||||||
g_irqCpup[intNum].allTime += usedTime;
|
g_irqCpup[cpupIntNum].allTime += usedTime;
|
||||||
g_irqCpup[intNum].count++;
|
g_irqCpup[cpupIntNum].count++;
|
||||||
} else {
|
} else {
|
||||||
g_irqCpup[intNum].allTime = 0;
|
g_irqCpup[cpupIntNum].allTime = 0;
|
||||||
g_irqCpup[intNum].count = 0;
|
g_irqCpup[cpupIntNum].count = 0;
|
||||||
}
|
}
|
||||||
g_irqCpup[intNum].startTime = 0;
|
g_irqCpup[cpupIntNum].startTime = 0;
|
||||||
if (usedTime > g_irqCpup[intNum].timeMax) {
|
if (usedTime > g_irqCpup[cpupIntNum].timeMax) {
|
||||||
g_irqCpup[intNum].timeMax = usedTime;
|
g_irqCpup[cpupIntNum].timeMax = usedTime;
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue