|
|
/* ----------------------------------------------------------------------------
|
|
|
* Copyright (c) Huawei Technologies Co., Ltd. 2013-2019. All rights reserved.
|
|
|
* Description: Hwi Shell Implementation
|
|
|
* Author: Huawei LiteOS Team
|
|
|
* Create: 2013-01-01
|
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
|
* are permitted provided that the following conditions are met:
|
|
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
|
|
* conditions and the following disclaimer.
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
|
|
* of conditions and the following disclaimer in the documentation and/or other materials
|
|
|
* provided with the distribution.
|
|
|
* 3. Neither the name of the copyright holder nor the names of its contributors may be used
|
|
|
* to endorse or promote products derived from this software without specific prior written
|
|
|
* permission.
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
|
|
|
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
|
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
|
|
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
|
|
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
|
|
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
* --------------------------------------------------------------------------- */
|
|
|
/*
|
|
|
这个文件是针对LiteOS操作系统中的Shell命令编写的,主要实现了对硬件中断信息的获取和显示功能,
|
|
|
包括了对硬件中断的共享模式、响应次数、CPU利用率等信息的获取和显示。根据操作系统配置不同,
|
|
|
还包括了对CPU利用率的不同时间段(所有时间、最近10秒、最近1秒)的统计和显示。
|
|
|
*/
|
|
|
#include "los_config.h"
|
|
|
#ifdef LOSCFG_SHELL
|
|
|
#ifdef LOSCFG_CPUP_INCLUDE_IRQ
|
|
|
#include "los_cpup_pri.h"
|
|
|
#endif
|
|
|
#include "los_hwi_pri.h"
|
|
|
#include "shcmd.h"
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
#if __cplusplus
|
|
|
extern "C" {
|
|
|
#endif /* __cplusplus */
|
|
|
#endif /* __cplusplus */
|
|
|
//这个函数实现了打印硬件中断信息的表头
|
|
|
LITE_OS_SEC_TEXT_MINOR STATIC VOID OsShellCmdHwiInfoTitle(VOID)
|
|
|
{
|
|
|
#ifdef LOSCFG_CPUP_INCLUDE_IRQ
|
|
|
PRINTK("InterruptNo Share ResponseCount CYCLECOST CPUUSE CPUUSE10s CPUUSE1s Name"
|
|
|
" DevId\n");
|
|
|
PRINTK("----------- ----- ------------- --------- ------ --------- -------- ---------"
|
|
|
" --------\n");
|
|
|
|
|
|
#else
|
|
|
PRINTK("InterruptNo Share ResponseCount Name DevId\n");
|
|
|
PRINTK("----------- ----- ------------- --------- --------\n");
|
|
|
#endif
|
|
|
}
|
|
|
//这个函数会根据传入的硬件中断句柄信息,获取该中断是否为共享模式
|
|
|
STATIC BOOL GetHwiShare(const HwiHandleInfo *hwiForm)
|
|
|
{
|
|
|
#ifndef LOSCFG_SHARED_IRQ
|
|
|
return false;
|
|
|
#else
|
|
|
return (hwiForm->shareMode);
|
|
|
#endif
|
|
|
}
|
|
|
|
|
|
#ifdef LOSCFG_CPUP_INCLUDE_IRQ
|
|
|
STATIC CPUP_INFO_S g_hwiCpupAll[LOSCFG_PLATFORM_HWI_LIMIT];//所有时间段CPU利用率的统计信息
|
|
|
STATIC CPUP_INFO_S g_hwiCpup10s[LOSCFG_PLATFORM_HWI_LIMIT];//最近10sCPU利用率的统计信息
|
|
|
STATIC CPUP_INFO_S g_hwiCpup1s[LOSCFG_PLATFORM_HWI_LIMIT];//最近1sCPU利用率的统计信息
|
|
|
//这个函数实现了硬件中断信息的查询,根据参数argc和argv判断是否有误,并调用其他函数获取硬件中断的各项信息,最终打印输出硬件中断的详细信息。
|
|
|
LITE_OS_SEC_TEXT_MINOR UINT32 OsShellCmdHwi(INT32 argc, const CHAR **argv)
|
|
|
{
|
|
|
UINT32 i, intSave;
|
|
|
UINT64 cycles = 0;
|
|
|
size_t size = sizeof(CPUP_INFO_S) * LOSCFG_PLATFORM_HWI_LIMIT;
|
|
|
HwiHandleInfo *hwiForm = NULL;
|
|
|
|
|
|
(VOID)argv;
|
|
|
//打印错误信息
|
|
|
if (argc > 0) {
|
|
|
PRINTK("\nUsage: hwi\n");
|
|
|
return OS_ERROR;
|
|
|
}
|
|
|
|
|
|
(VOID)memset_s(g_hwiCpupAll, size, 0, size);//置零
|
|
|
(VOID)memset_s(g_hwiCpup10s, size, 0, size);//置零
|
|
|
(VOID)memset_s(g_hwiCpup1s, size, 0, size);//置零
|
|
|
|
|
|
intSave = LOS_IntLock();
|
|
|
(VOID)LOS_AllCpuUsage(LOSCFG_PLATFORM_HWI_LIMIT, g_hwiCpupAll, CPUP_ALL_TIME, 0);
|
|
|
(VOID)LOS_AllCpuUsage(LOSCFG_PLATFORM_HWI_LIMIT, g_hwiCpup10s, CPUP_LAST_TEN_SECONDS, 0);
|
|
|
(VOID)LOS_AllCpuUsage(LOSCFG_PLATFORM_HWI_LIMIT, g_hwiCpup1s, CPUP_LAST_ONE_SECONDS, 0);
|
|
|
LOS_IntRestore(intSave);
|
|
|
//打印硬件中断信息的表头
|
|
|
OsShellCmdHwiInfoTitle();
|
|
|
//打印CPU硬件中断的利用率
|
|
|
for (i = 0; i < LOSCFG_PLATFORM_HWI_LIMIT; i++) {
|
|
|
if (!HWI_IS_REGISTED(i)) {
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
if (OsGetHwiFormCnt(i)) {
|
|
|
cycles = (OsCpupCBGet(g_taskMaxNum + i))->allTime / OsGetHwiFormCnt(i);
|
|
|
}
|
|
|
|
|
|
/* Different cores has different hwi form implementation */
|
|
|
//打印各个时间内的硬件中断利用率
|
|
|
hwiForm = OsGetHwiForm(i);
|
|
|
PRINTK("%-8u\t %-s\t %-10u\t %-10llu %2u.%-7u %2u.%-7u %2u.%-6u",
|
|
|
i, GetHwiShare(hwiForm) ? "Y" : "N", OsGetHwiFormCnt(i), cycles,
|
|
|
g_hwiCpupAll[i].uwUsage / LOS_CPUP_PRECISION_MULT, g_hwiCpupAll[i].uwUsage % LOS_CPUP_PRECISION_MULT,
|
|
|
g_hwiCpup10s[i].uwUsage / LOS_CPUP_PRECISION_MULT, g_hwiCpup10s[i].uwUsage % LOS_CPUP_PRECISION_MULT,
|
|
|
g_hwiCpup1s[i].uwUsage / LOS_CPUP_PRECISION_MULT, g_hwiCpup1s[i].uwUsage % LOS_CPUP_PRECISION_MULT);
|
|
|
#ifdef LOSCFG_SHARED_IRQ
|
|
|
hwiForm = hwiForm->next;
|
|
|
#endif
|
|
|
//打印中断设备ID和信息
|
|
|
if ((hwiForm->registerInfo != 0) && ((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pName != NULL) {
|
|
|
PRINTK("\t %-16s 0x%-.8x\n",
|
|
|
((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pName,
|
|
|
((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pDevId);
|
|
|
} else {
|
|
|
PRINTK("\n");
|
|
|
}
|
|
|
#ifdef LOSCFG_SHARED_IRQ
|
|
|
while ((hwiForm = hwiForm->next) != NULL) {
|
|
|
PRINTK("\t\t\t\t\t\t\t\t\t\t\t\t %-16s 0x%-.8x\n",
|
|
|
((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pName,
|
|
|
((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pDevId);
|
|
|
}
|
|
|
#endif
|
|
|
}
|
|
|
return 0;
|
|
|
}
|
|
|
#else
|
|
|
//这个函数主要实现对hwi命令的解释功能,输出硬件中断信息
|
|
|
LITE_OS_SEC_TEXT_MINOR UINT32 OsShellCmdHwi(INT32 argc, const CHAR **argv)
|
|
|
{
|
|
|
UINT32 i;
|
|
|
HwiHandleInfo *hwiForm = NULL;
|
|
|
|
|
|
//参数错误,打印错误信息
|
|
|
(VOID)argv;
|
|
|
if (argc > 0) {
|
|
|
PRINTK("\nUsage: hwi\n");
|
|
|
return OS_ERROR;
|
|
|
}
|
|
|
//打印硬件中断信息的表头
|
|
|
OsShellCmdHwiInfoTitle();
|
|
|
//遍历所有硬件中断寄存器
|
|
|
for (i = 0; i < LOSCFG_PLATFORM_HWI_LIMIT; i++) {
|
|
|
if (!HWI_IS_REGISTED(i)) {
|
|
|
continue;
|
|
|
}
|
|
|
|
|
|
/* Different cores has different hwi form implementation */
|
|
|
//输出信息
|
|
|
hwiForm = OsGetHwiForm(i);
|
|
|
PRINTK("%-8u\t %-s\t %-10u", i, GetHwiShare(hwiForm) ? "Y" : "N", OsGetHwiFormCnt(i));
|
|
|
#ifdef LOSCFG_SHARED_IRQ
|
|
|
hwiForm = hwiForm->next;
|
|
|
#endif
|
|
|
if ((hwiForm->registerInfo != 0) && ((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pName != NULL) {
|
|
|
PRINTK("\t %-16s 0x%-.8x\n",
|
|
|
((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pName,
|
|
|
((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pDevId);
|
|
|
} else {
|
|
|
PRINTK("\n");
|
|
|
}
|
|
|
|
|
|
#ifdef LOSCFG_SHARED_IRQ
|
|
|
while ((hwiForm = hwiForm->next) != NULL) {
|
|
|
PRINTK("\t\t\t\t\t %-16s 0x%-.8x\n",
|
|
|
((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pName,
|
|
|
((HWI_IRQ_PARAM_S *)hwiForm->registerInfo)->pDevId);
|
|
|
}
|
|
|
#endif
|
|
|
}
|
|
|
return 0;
|
|
|
}
|
|
|
#endif
|
|
|
//该函数实现了OsShellCmdHwi的函数调用,用户可以输入hwi命令来调用该函数,从而查询和展示硬件中断信息
|
|
|
SHELLCMD_ENTRY(hwi_shellcmd, CMD_TYPE_EX, "hwi", 0, (CmdCallBackFunc)OsShellCmdHwi);
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
#if __cplusplus
|
|
|
}
|
|
|
#endif /* __cplusplus */
|
|
|
#endif /* __cplusplus */
|
|
|
#endif /* LOSCFG_SHELL */
|