|  | // SPDX-License-Identifier: GPL-2.0-only | 
|  | /* | 
|  | * Smart reflex Class 3 specific implementations | 
|  | * | 
|  | * Author: Thara Gopinath       <thara@ti.com> | 
|  | * | 
|  | * Copyright (C) 2010 Texas Instruments, Inc. | 
|  | * Thara Gopinath <thara@ti.com> | 
|  | */ | 
|  |  | 
|  | #include <linux/power/smartreflex.h> | 
|  | #include "soc.h" | 
|  | #include "voltage.h" | 
|  |  | 
|  | static int sr_class3_enable(struct omap_sr *sr) | 
|  | { | 
|  | unsigned long volt = voltdm_get_voltage(sr->voltdm); | 
|  |  | 
|  | if (!volt) { | 
|  | pr_warn("%s: Curr voltage unknown. Cannot enable %s\n", | 
|  | __func__, sr->name); | 
|  | return -ENODATA; | 
|  | } | 
|  |  | 
|  | omap_vp_enable(sr->voltdm); | 
|  | return sr_enable(sr, volt); | 
|  | } | 
|  |  | 
|  | static int sr_class3_disable(struct omap_sr *sr, int is_volt_reset) | 
|  | { | 
|  | sr_disable_errgen(sr); | 
|  | omap_vp_disable(sr->voltdm); | 
|  | sr_disable(sr); | 
|  | if (is_volt_reset) | 
|  | voltdm_reset(sr->voltdm); | 
|  |  | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | static int sr_class3_configure(struct omap_sr *sr) | 
|  | { | 
|  | return sr_configure_errgen(sr); | 
|  | } | 
|  |  | 
|  | /* 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); | 
|  | } | 
|  | omap_late_initcall(sr_class3_init); |