2014-08-19 20:17:35 +04:00
/*
* Intel Low Power Subsystem PWM controller driver
*
* Copyright ( C ) 2014 , Intel Corporation
*
* Derived from the original pwm - lpss . c
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*/
# include <linux/acpi.h>
# include <linux/kernel.h>
# include <linux/module.h>
# include <linux/platform_device.h>
2015-10-26 13:58:27 +03:00
# include <linux/pm_runtime.h>
2014-08-19 20:17:35 +04:00
# include "pwm-lpss.h"
2017-01-28 18:10:43 +03:00
/* BayTrail */
static const struct pwm_lpss_boardinfo pwm_lpss_byt_info = {
. clk_rate = 25000000 ,
. npwm = 1 ,
. base_unit_bits = 16 ,
} ;
/* Braswell */
static const struct pwm_lpss_boardinfo pwm_lpss_bsw_info = {
. clk_rate = 19200000 ,
. npwm = 1 ,
. base_unit_bits = 16 ,
} ;
/* Broxton */
static const struct pwm_lpss_boardinfo pwm_lpss_bxt_info = {
. clk_rate = 19200000 ,
. npwm = 4 ,
. base_unit_bits = 22 ,
2017-04-06 14:54:01 +03:00
. bypass = true ,
2017-01-28 18:10:43 +03:00
} ;
2014-08-19 20:17:35 +04:00
static int pwm_lpss_probe_platform ( struct platform_device * pdev )
{
const struct pwm_lpss_boardinfo * info ;
const struct acpi_device_id * id ;
struct pwm_lpss_chip * lpwm ;
struct resource * r ;
id = acpi_match_device ( pdev - > dev . driver - > acpi_match_table , & pdev - > dev ) ;
if ( ! id )
return - ENODEV ;
info = ( const struct pwm_lpss_boardinfo * ) id - > driver_data ;
r = platform_get_resource ( pdev , IORESOURCE_MEM , 0 ) ;
lpwm = pwm_lpss_probe ( & pdev - > dev , r , info ) ;
if ( IS_ERR ( lpwm ) )
return PTR_ERR ( lpwm ) ;
platform_set_drvdata ( pdev , lpwm ) ;
2015-10-26 13:58:27 +03:00
pm_runtime_set_active ( & pdev - > dev ) ;
pm_runtime_enable ( & pdev - > dev ) ;
2014-08-19 20:17:35 +04:00
return 0 ;
}
static int pwm_lpss_remove_platform ( struct platform_device * pdev )
{
struct pwm_lpss_chip * lpwm = platform_get_drvdata ( pdev ) ;
2015-10-26 13:58:27 +03:00
pm_runtime_disable ( & pdev - > dev ) ;
2014-08-19 20:17:35 +04:00
return pwm_lpss_remove ( lpwm ) ;
}
static const struct acpi_device_id pwm_lpss_acpi_match [ ] = {
{ " 80860F09 " , ( unsigned long ) & pwm_lpss_byt_info } ,
{ " 80862288 " , ( unsigned long ) & pwm_lpss_bsw_info } ,
2015-10-20 16:53:07 +03:00
{ " 80865AC8 " , ( unsigned long ) & pwm_lpss_bxt_info } ,
2014-08-19 20:17:35 +04:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( acpi , pwm_lpss_acpi_match ) ;
static struct platform_driver pwm_lpss_driver_platform = {
. driver = {
. name = " pwm-lpss " ,
. acpi_match_table = pwm_lpss_acpi_match ,
} ,
. probe = pwm_lpss_probe_platform ,
. remove = pwm_lpss_remove_platform ,
} ;
module_platform_driver ( pwm_lpss_driver_platform ) ;
MODULE_DESCRIPTION ( " PWM platform driver for Intel LPSS " ) ;
MODULE_LICENSE ( " GPL v2 " ) ;
MODULE_ALIAS ( " platform:pwm-lpss " ) ;