2019-06-04 16:11:33 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
2010-05-30 00:32:25 +08:00
|
|
|
/*
|
|
|
|
* Smart reflex Class 3 specific implementations
|
|
|
|
*
|
|
|
|
* Author: Thara Gopinath <thara@ti.com>
|
|
|
|
*
|
|
|
|
* Copyright (C) 2010 Texas Instruments, Inc.
|
|
|
|
* Thara Gopinath <thara@ti.com>
|
|
|
|
*/
|
|
|
|
|
2012-04-25 18:36:20 +08:00
|
|
|
#include <linux/power/smartreflex.h>
|
2013-02-10 11:20:57 +08:00
|
|
|
#include "soc.h"
|
2012-04-25 18:36:20 +08:00
|
|
|
#include "voltage.h"
|
2010-05-30 00:32:25 +08:00
|
|
|
|
2012-04-24 12:52:12 +08:00
|
|
|
static int sr_class3_enable(struct omap_sr *sr)
|
2010-05-30 00:32:25 +08:00
|
|
|
{
|
2012-04-24 12:52:12 +08:00
|
|
|
unsigned long volt = voltdm_get_voltage(sr->voltdm);
|
2010-05-30 00:32:25 +08:00
|
|
|
|
|
|
|
if (!volt) {
|
2014-09-14 02:31:16 +08:00
|
|
|
pr_warn("%s: Curr voltage unknown. Cannot enable %s\n",
|
|
|
|
__func__, sr->name);
|
2010-05-30 00:32:25 +08:00
|
|
|
return -ENODATA;
|
|
|
|
}
|
|
|
|
|
2012-04-24 12:52:12 +08:00
|
|
|
omap_vp_enable(sr->voltdm);
|
2013-05-27 19:09:24 +08:00
|
|
|
return sr_enable(sr, volt);
|
2010-05-30 00:32:25 +08:00
|
|
|
}
|
|
|
|
|
2012-04-24 12:52:12 +08:00
|
|
|
static int sr_class3_disable(struct omap_sr *sr, int is_volt_reset)
|
2010-05-30 00:32:25 +08:00
|
|
|
{
|
2013-05-27 19:09:22 +08:00
|
|
|
sr_disable_errgen(sr);
|
2012-04-24 12:52:12 +08:00
|
|
|
omap_vp_disable(sr->voltdm);
|
2013-05-27 19:09:24 +08:00
|
|
|
sr_disable(sr);
|
2010-05-30 00:32:25 +08:00
|
|
|
if (is_volt_reset)
|
2012-04-24 12:52:12 +08:00
|
|
|
voltdm_reset(sr->voltdm);
|
2010-05-30 00:32:25 +08:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-04-24 12:52:12 +08:00
|
|
|
static int sr_class3_configure(struct omap_sr *sr)
|
2010-05-30 00:32:25 +08:00
|
|
|
{
|
2013-05-27 19:09:22 +08:00
|
|
|
return sr_configure_errgen(sr);
|
2010-05-30 00:32:25 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/* SR class3 structure */
|
|
|
|
static struct omap_sr_class_data class3_data = {
|
|
|
|
.enable = sr_class3_enable,
|
|
|
|
.disable = sr_class3_disable,
|
|
|
|
.configure = sr_class3_configure,
|
|
|
|
.class_type = SR_CLASS3,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Smartreflex Class3 init API to be called from board file */
|
|
|
|
static int __init sr_class3_init(void)
|
|
|
|
{
|
|
|
|
pr_info("SmartReflex Class3 initialized\n");
|
|
|
|
return sr_register_class(&class3_data);
|
|
|
|
}
|
2013-01-12 03:24:18 +08:00
|
|
|
omap_late_initcall(sr_class3_init);
|