Skip to content

Commit

Permalink
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #9 from itsshashanksp/sleepy
Browse files Browse the repository at this point in the history
Merge sleepy branch
itsshashanksp authored Jun 2, 2024
2 parents 5331a69 + 27260ff commit 9290d8f
Showing 7 changed files with 350 additions and 2 deletions.
5 changes: 3 additions & 2 deletions arch/arm64/configs/vendor/sdmsteppe-perf_defconfig
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#
# Automatically generated file; DO NOT EDIT.
# Linux/arm64 4.14.344-openela Kernel Configuration
# Linux/arm64 4.14.345-openela Kernel Configuration
#
CONFIG_ARM64=y
CONFIG_64BIT=y
@@ -730,6 +730,7 @@ CONFIG_WQ_POWER_EFFICIENT_DEFAULT=y
CONFIG_PM_GENERIC_DOMAINS_SLEEP=y
CONFIG_PM_GENERIC_DOMAINS_OF=y
CONFIG_CPU_PM=y
CONFIG_BOEFFLA_WL_BLOCKER=y
CONFIG_ARCH_HIBERNATION_POSSIBLE=y
CONFIG_ARCH_SUSPEND_POSSIBLE=y

@@ -4469,7 +4470,7 @@ CONFIG_QCOM_DEVFREQ_DEVBW=y
# CONFIG_DEVFREQ_SPDM is not set
CONFIG_DEVFREQ_GOV_CDSPL3=y
CONFIG_DEVFREQ_BOOST=y
CONFIG_DEVFREQ_INPUT_BOOST_DURATION_MS=100
CONFIG_DEVFREQ_INPUT_BOOST_DURATION_MS=200
CONFIG_DEVFREQ_WAKE_BOOST_DURATION_MS=1000
CONFIG_DEVFREQ_MSM_CPUBW_BOOST_FREQ=7110
CONFIG_DEVFREQ_MSM_LLCCBW_BOOST_FREQ=3879
1 change: 1 addition & 0 deletions drivers/base/power/Makefile
Original file line number Diff line number Diff line change
@@ -5,5 +5,6 @@ obj-$(CONFIG_PM_TRACE_RTC) += trace.o
obj-$(CONFIG_PM_OPP) += opp/
obj-$(CONFIG_PM_GENERIC_DOMAINS) += domain.o domain_governor.o
obj-$(CONFIG_HAVE_CLK) += clock_ops.o
obj-$(CONFIG_BOEFFLA_WL_BLOCKER) += boeffla_wl_blocker.o

ccflags-$(CONFIG_DEBUG_DRIVER) := -DDEBUG
235 changes: 235 additions & 0 deletions drivers/base/power/boeffla_wl_blocker.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,235 @@
/*
* Author: andip71, 01.09.2017
*
* Version 1.1.0
*
* This software is licensed under the terms of the GNU General Public
* License version 2, as published by the Free Software Foundation, and
* may be copied, distributed, and modified under those terms.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
*/

/*
* Change log:
*
* 1.1.0 (01.09.2017)
* - By default, the following wakelocks are blocked in an own list
* qcom_rx_wakelock, wlan, wlan_wow_wl, wlan_extscan_wl, NETLINK
*
* 1.0.1 (29.08.2017)
* - Add killing wakelock when currently active
*
* 1.0.0 (28.08.2017)
* - Initial version
*
*/

#include <linux/module.h>
#include <linux/kobject.h>
#include <linux/sysfs.h>
#include <linux/device.h>
#include <linux/miscdevice.h>
#include "boeffla_wl_blocker.h"


/*
Variables
*/

char list_wl[LENGTH_LIST_WL] = {0};
char list_wl_default[LENGTH_LIST_WL_DEFAULT] = {0};

extern char list_wl_search[LENGTH_LIST_WL_SEARCH];
extern bool wl_blocker_active;
extern bool wl_blocker_debug;


/*
Internal functions
*/

static void build_search_string(char *list1, char *list2)
{
/* store wakelock list and search string (with semicolons added at start and end) */
snprintf(list_wl_search, sizeof(list_wl_search), ";%s;%s;", list1, list2);

/* set flag if wakelock blocker should be active (for performance reasons) */
if (strlen(list_wl_search) > 5)
wl_blocker_active = true;
else
wl_blocker_active = false;
}


/*
sysfs interface functions
*/

/* show list of user configured wakelocks */
static ssize_t wakelock_blocker_show(struct device *dev, struct device_attribute *attr,
char *buf)
{
/* return list of wakelocks to be blocked */
return snprintf(buf, sizeof(list_wl), "%s\n", list_wl);
}


/* store list of user configured wakelocks */
static ssize_t wakelock_blocker_store(struct device *dev, struct device_attribute *attr,
const char *buf, size_t n)
{
int len = n;

/* check if string is too long to be stored */
if (len > LENGTH_LIST_WL)
return -EINVAL;

/* store user configured wakelock list and rebuild search string */
sscanf(buf, "%s", list_wl);
build_search_string(list_wl_default, list_wl);

return n;
}


/* show list of default, predefined wakelocks */
static ssize_t wakelock_blocker_default_show(struct device *dev, struct device_attribute *attr,
char *buf)
{
/* return list of wakelocks to be blocked */
return snprintf(buf, sizeof(list_wl_default), "%s\n", list_wl_default);
}


/* store list of default, predefined wakelocks */
static ssize_t wakelock_blocker_default_store(struct device *dev, struct device_attribute *attr,
const char *buf, size_t n)
{
int len = n;

/* check if string is too long to be stored */
if (len > LENGTH_LIST_WL_DEFAULT)
return -EINVAL;

/* store default, predefined wakelock list and rebuild search string */
sscanf(buf, "%s", list_wl_default);
build_search_string(list_wl_default, list_wl);

return n;
}


/* show debug information of driver internals */
static ssize_t debug_show(struct device *dev, struct device_attribute *attr, char *buf)
{
/* return current debug status */
return sprintf(buf, "Debug status: %d\n\nUser list: %s\nDefault list: %s\nSearch list: %s\nActive: %d\n",
wl_blocker_debug, list_wl, list_wl_default, list_wl_search, wl_blocker_active);
}


/* store debug mode on/off (1/0) */
static ssize_t debug_store(struct device *dev, struct device_attribute *attr,
const char *buf, size_t count)
{
unsigned int ret = -EINVAL;
unsigned int val;

/* check data and store if valid */
ret = sscanf(buf, "%d", &val);

if (ret != 1)
return -EINVAL;

if (val == 1)
wl_blocker_debug = true;
else
wl_blocker_debug = false;

return count;
}


static ssize_t version_show(struct device *dev, struct device_attribute *attr, char *buf)
{
/* return version information */
return snprintf(buf, sizeof(BOEFFLA_WL_BLOCKER_VERSION), "%s\n", BOEFFLA_WL_BLOCKER_VERSION);
}



/*
Initialize sysfs objects
*/

/* define objects */
static DEVICE_ATTR(wakelock_blocker, 0644, wakelock_blocker_show, wakelock_blocker_store);
static DEVICE_ATTR(wakelock_blocker_default, 0644, wakelock_blocker_default_show, wakelock_blocker_default_store);
static DEVICE_ATTR(debug, 0664, debug_show, debug_store);
static DEVICE_ATTR(version, 0664, version_show, NULL);

/* define attributes */
static struct attribute *boeffla_wl_blocker_attributes[] = {
&dev_attr_wakelock_blocker.attr,
&dev_attr_wakelock_blocker_default.attr,
&dev_attr_debug.attr,
&dev_attr_version.attr,
NULL
};

/* define attribute group */
static struct attribute_group boeffla_wl_blocker_control_group = {
.attrs = boeffla_wl_blocker_attributes,
};

/* define control device */
static struct miscdevice boeffla_wl_blocker_control_device = {
.minor = MISC_DYNAMIC_MINOR,
.name = "boeffla_wakelock_blocker",
};


/*
Driver init and exit functions
*/

static int boeffla_wl_blocker_init(void)
{
/* register boeffla wakelock blocker control device */
misc_register(&boeffla_wl_blocker_control_device);
if (sysfs_create_group(&boeffla_wl_blocker_control_device.this_device->kobj,
&boeffla_wl_blocker_control_group) < 0) {
pr_debug("Boeffla WL blocker: failed to create sys fs object.\n");
return 0;
}

/* initialize default list */
snprintf(list_wl_default, sizeof(LIST_WL_DEFAULT), "%s", LIST_WL_DEFAULT);
build_search_string(list_wl_default, list_wl);

/* Print debug info */
pr_debug("Boeffla WL blocker: driver version %s started\n", BOEFFLA_WL_BLOCKER_VERSION);

return 0;
}


static void boeffla_wl_blocker_exit(void)
{
/* remove boeffla wakelock blocker control device */
sysfs_remove_group(&boeffla_wl_blocker_control_device.this_device->kobj,
&boeffla_wl_blocker_control_group);

/* Print debug info */
pr_debug("Boeffla WL blocker: driver stopped\n");
}


/* define driver entry points */
module_init(boeffla_wl_blocker_init);
module_exit(boeffla_wl_blocker_exit);
23 changes: 23 additions & 0 deletions drivers/base/power/boeffla_wl_blocker.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
/*
* Author: andip71, 01.09.2017
*
* Version 1.1.0
*
* This software is licensed under the terms of the GNU General Public
* License version 2, as published by the Free Software Foundation, and
* may be copied, distributed, and modified under those terms.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
*/

#define BOEFFLA_WL_BLOCKER_VERSION "1.1.0"

#define LIST_WL_DEFAULT ""

#define LENGTH_LIST_WL 512
#define LENGTH_LIST_WL_DEFAULT 512
#define LENGTH_LIST_WL_SEARCH LENGTH_LIST_WL + LENGTH_LIST_WL_DEFAULT + 5
4 changes: 4 additions & 0 deletions drivers/base/power/main.c
Original file line number Diff line number Diff line change
@@ -780,6 +780,10 @@ void dpm_resume_early(pm_message_t state)
struct device *dev;
ktime_t starttime = ktime_get();

#ifdef CONFIG_BOEFFLA_WL_BLOCKER
pm_print_active_wakeup_sources();
#endif

trace_suspend_resume(TPS("dpm_resume_early"), state.event, true);
mutex_lock(&dpm_list_mtx);
pm_transition = state;
Loading

0 comments on commit 9290d8f

Please sign in to comment.