feat: L1支持低功耗投票框架

功能描述:
  在proc目录下增加power目录,添加powr_mode,power_lock,power_unlock和power_count节点,
  power_mode:节点用于查询和设置系统支持的功耗模式
  power_lock:用于查询和获取低功耗锁,持锁后,将会阻止系统进入低功耗状态
  power_unlock: 用于释放已经持有的低功耗锁,也可查询当前有那些持有低功耗锁
  power_count:用于查询当前持有低功耗锁的个数

Close #I3VS5N

Change-Id: I2e2881cc968eab3c5fa6f9dbd7e8c5e448609407
Signed-off-by: zhushengle <zhushengle@huawei.com>
This commit is contained in:
zhushengle
2021-06-23 18:14:46 +08:00
parent 8a3d188240
commit 21d8ac8752
10 changed files with 623 additions and 1 deletions

View File

@@ -45,6 +45,8 @@ extern "C" {
extern spinlock_t procfsLock;
extern bool procfsInit;
void ProcPmInit(void);
void ProcVmmInit(void);
void ProcProcessInit(void);

View File

@@ -0,0 +1,178 @@
/*
* Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
* Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
*
* 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.
*/
#include <sys/statfs.h>
#include <sys/mount.h>
#include "proc_fs.h"
#include "internal.h"
#ifdef LOSCFG_KERNEL_PM
#include "los_pm.h"
static int PowerLockWrite(struct ProcFile *pf, const char *buf, size_t count, loff_t *ppos)
{
(void)pf;
(void)count;
(void)ppos;
return -LOS_PmLockRequest(buf);
}
static int PowerLockRead(struct SeqBuf *m, void *v)
{
(void)v;
LOS_PmLockInfoShow(m);
return 0;
}
static const struct ProcFileOperations PowerLock = {
.write = PowerLockWrite,
.read = PowerLockRead,
};
static int PowerUnlockWrite(struct ProcFile *pf, const char *buf, size_t count, loff_t *ppos)
{
(void)pf;
(void)count;
(void)ppos;
return -LOS_PmLockRelease(buf);
}
static const struct ProcFileOperations PowerUnlock = {
.write = PowerUnlockWrite,
.read = PowerLockRead,
};
static int PowerModeWrite(struct ProcFile *pf, const char *buf, size_t count, loff_t *ppos)
{
(void)pf;
(void)count;
(void)ppos;
if (buf == NULL) {
return 0;
}
if (strcmp(buf, "normal") != 0) {
return LOS_NOK;
}
return 0;
}
static int PowerModeRead(struct SeqBuf *m, void *v)
{
(void)v;
LosBufPrintf(m, "normal \n");
return 0;
}
static const struct ProcFileOperations PowerMode = {
.write = PowerModeWrite,
.read = PowerModeRead,
};
static int PowerCountRead(struct SeqBuf *m, void *v)
{
(void)v;
UINT32 count = LOS_PmLockCountGet();
LosBufPrintf(m, "%u\n", count);
return 0;
}
static const struct ProcFileOperations PowerCount = {
.write = NULL,
.read = PowerCountRead,
};
#define POWER_FILE_MODE (S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH)
#define OS_POWER_PRIVILEGE 7
void ProcPmInit(void)
{
struct ProcDirEntry *power = CreateProcEntry("power", S_IFDIR | S_IRWXU | S_IRWXG | S_IROTH, NULL);
if (power == NULL) {
PRINT_ERR("create /proc/power error!\n");
return;
}
power->uid = OS_POWER_PRIVILEGE;
power->gid = OS_POWER_PRIVILEGE;
struct ProcDirEntry *mode = CreateProcEntry("power/power_mode", POWER_FILE_MODE, NULL);
if (mode == NULL) {
PRINT_ERR("create /proc/power/power_mode error!\n");
goto FREE_POWER;
}
mode->procFileOps = &PowerMode;
mode->uid = OS_POWER_PRIVILEGE;
mode->gid = OS_POWER_PRIVILEGE;
struct ProcDirEntry *lock = CreateProcEntry("power/power_lock", POWER_FILE_MODE, NULL);
if (lock == NULL) {
PRINT_ERR("create /proc/power/power_lock error!\n");
goto FREE_MODE;
}
lock->procFileOps = &PowerLock;
lock->uid = OS_POWER_PRIVILEGE;
lock->gid = OS_POWER_PRIVILEGE;
struct ProcDirEntry *unlock = CreateProcEntry("power/power_unlock", POWER_FILE_MODE, NULL);
if (unlock == NULL) {
PRINT_ERR("create /proc/power/power_unlock error!\n");
goto FREE_LOCK;
}
unlock->procFileOps = &PowerUnlock;
unlock->uid = OS_POWER_PRIVILEGE;
unlock->gid = OS_POWER_PRIVILEGE;
struct ProcDirEntry *count = CreateProcEntry("power/power_count", S_IRUSR | S_IRGRP | S_IROTH, NULL);
if (count == NULL) {
PRINT_ERR("create /proc/power/power_count error!\n");
goto FREE_UNLOCK;
}
count->procFileOps = &PowerCount;
count->uid = OS_POWER_PRIVILEGE;
count->gid = OS_POWER_PRIVILEGE;
return;
FREE_UNLOCK:
ProcFreeEntry(unlock);
FREE_LOCK:
ProcFreeEntry(lock);
FREE_MODE:
ProcFreeEntry(mode);
FREE_POWER:
ProcFreeEntry(power);
return;
}
#endif

View File

@@ -66,6 +66,9 @@ void ProcFsInit(void)
ProcKernelTraceInit();
ProcFsCacheInit();
ProcFdInit();
#ifdef LOSCFG_KERNEL_PM
ProcPmInit();
#endif
}
LOS_MODULE_INIT(ProcFsInit, LOS_INIT_LEVEL_KMOD_EXTENDED);