blob: 955566eefac4ac515516957e3f6d65cbc3353c35 [file] [log] [blame]
Thara Gopinathfa765822010-05-29 22:02:25 +05301/*
2 * Smart reflex Class 3 specific implementations
3 *
4 * Author: Thara Gopinath <thara@ti.com>
5 *
6 * Copyright (C) 2010 Texas Instruments, Inc.
7 * Thara Gopinath <thara@ti.com>
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License version 2 as
11 * published by the Free Software Foundation.
12 */
13
Paul Walmsley7328ff42011-02-25 15:54:33 -070014#include "smartreflex.h"
Thara Gopinathfa765822010-05-29 22:02:25 +053015
16static int sr_class3_enable(struct voltagedomain *voltdm)
17{
Kevin Hilmand5c12822011-07-15 16:05:12 -070018 unsigned long volt = voltdm_get_voltage(voltdm);
Thara Gopinathfa765822010-05-29 22:02:25 +053019
20 if (!volt) {
21 pr_warning("%s: Curr voltage unknown. Cannot enable sr_%s\n",
22 __func__, voltdm->name);
23 return -ENODATA;
24 }
25
26 omap_vp_enable(voltdm);
27 return sr_enable(voltdm, volt);
28}
29
30static int sr_class3_disable(struct voltagedomain *voltdm, int is_volt_reset)
31{
Nishanth Menonad54c3d2012-02-29 23:33:39 +010032 sr_disable_errgen(voltdm);
Thara Gopinathfa765822010-05-29 22:02:25 +053033 omap_vp_disable(voltdm);
34 sr_disable(voltdm);
35 if (is_volt_reset)
Kevin Hilman5e5651b2011-04-05 16:27:21 -070036 voltdm_reset(voltdm);
Thara Gopinathfa765822010-05-29 22:02:25 +053037
38 return 0;
39}
40
41static int sr_class3_configure(struct voltagedomain *voltdm)
42{
43 return sr_configure_errgen(voltdm);
44}
45
46/* SR class3 structure */
47static struct omap_sr_class_data class3_data = {
48 .enable = sr_class3_enable,
49 .disable = sr_class3_disable,
50 .configure = sr_class3_configure,
51 .class_type = SR_CLASS3,
52};
53
54/* Smartreflex Class3 init API to be called from board file */
55static int __init sr_class3_init(void)
56{
57 pr_info("SmartReflex Class3 initialized\n");
58 return sr_register_class(&class3_data);
59}
60late_initcall(sr_class3_init);