| /* Copyright (c) 2013 The Chromium OS Authors. All rights reserved. |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| |
| /* PWM control module for LM4. |
| * |
| * On this chip, the PWM logic is implemented by the hardware FAN modules. |
| */ |
| |
| #include "clock.h" |
| #include "fan.h" |
| #include "gpio.h" |
| #include "hooks.h" |
| #include "pwm.h" |
| #include "pwm_chip.h" |
| #include "registers.h" |
| #include "util.h" |
| |
| void pwm_enable(enum pwm_channel ch, int enabled) |
| { |
| fan_set_enabled(pwm_channels[ch].channel, enabled); |
| } |
| |
| int pwm_get_enabled(enum pwm_channel ch) |
| { |
| return fan_get_enabled(pwm_channels[ch].channel); |
| } |
| |
| void pwm_set_duty(enum pwm_channel ch, int percent) |
| { |
| if (percent < 0) |
| percent = 0; |
| else if (percent > 100) |
| percent = 100; |
| |
| /* Assume the fan control is active high and invert it ourselves */ |
| if (pwm_channels[ch].flags & PWM_CONFIG_ACTIVE_LOW) |
| percent = 100 - percent; |
| |
| /* Always enable the channel */ |
| pwm_enable(ch, 1); |
| |
| /* Set the duty cycle */ |
| fan_set_duty(pwm_channels[ch].channel, percent); |
| } |
| |
| int pwm_get_duty(enum pwm_channel ch) |
| { |
| int percent = fan_get_duty(pwm_channels[ch].channel); |
| |
| if (pwm_channels[ch].flags & PWM_CONFIG_ACTIVE_LOW) |
| percent = 100 - percent; |
| |
| return percent; |
| } |
| |
| static void pwm_init(void) |
| { |
| int i; |
| |
| for (i = 0; i < PWM_CH_COUNT; ++i) |
| fan_channel_setup(pwm_channels[i].channel, |
| (pwm_channels[i].flags & |
| PWM_CONFIG_HAS_RPM_MODE) |
| ? FAN_USE_RPM_MODE : 0); |
| } |
| |
| /* The chip-specific fan module initializes before this. */ |
| DECLARE_HOOK(HOOK_INIT, pwm_init, HOOK_PRIO_DEFAULT); |