Linux Audio

Check our new training course

Loading...
v6.8
  1// SPDX-License-Identifier: GPL-2.0-only
  2/*
  3 * Implements I2C interface for VTI CMA300_D0x Accelerometer driver
  4 *
  5 * Copyright (C) 2010 Texas Instruments
  6 * Author: Hemanth V <hemanthv@ti.com>
 
 
 
 
 
 
 
 
 
 
 
 
  7 */
  8
  9#include <linux/module.h>
 10#include <linux/i2c.h>
 11#include <linux/input/cma3000.h>
 12#include "cma3000_d0x.h"
 13
 14static int cma3000_i2c_set(struct device *dev,
 15			   u8 reg, u8 val, char *msg)
 16{
 17	struct i2c_client *client = to_i2c_client(dev);
 18	int ret;
 19
 20	ret = i2c_smbus_write_byte_data(client, reg, val);
 21	if (ret < 0)
 22		dev_err(&client->dev,
 23			"%s failed (%s, %d)\n", __func__, msg, ret);
 24	return ret;
 25}
 26
 27static int cma3000_i2c_read(struct device *dev, u8 reg, char *msg)
 28{
 29	struct i2c_client *client = to_i2c_client(dev);
 30	int ret;
 31
 32	ret = i2c_smbus_read_byte_data(client, reg);
 33	if (ret < 0)
 34		dev_err(&client->dev,
 35			"%s failed (%s, %d)\n", __func__, msg, ret);
 36	return ret;
 37}
 38
 39static const struct cma3000_bus_ops cma3000_i2c_bops = {
 40	.bustype	= BUS_I2C,
 41#define CMA3000_BUSI2C     (0 << 4)
 42	.ctrl_mod	= CMA3000_BUSI2C,
 43	.read		= cma3000_i2c_read,
 44	.write		= cma3000_i2c_set,
 45};
 46
 47static int cma3000_i2c_probe(struct i2c_client *client)
 
 48{
 49	struct cma3000_accl_data *data;
 50
 51	data = cma3000_init(&client->dev, client->irq, &cma3000_i2c_bops);
 52	if (IS_ERR(data))
 53		return PTR_ERR(data);
 54
 55	i2c_set_clientdata(client, data);
 56
 57	return 0;
 58}
 59
 60static void cma3000_i2c_remove(struct i2c_client *client)
 61{
 62	struct cma3000_accl_data *data = i2c_get_clientdata(client);
 63
 64	cma3000_exit(data);
 
 
 65}
 66
 
 67static int cma3000_i2c_suspend(struct device *dev)
 68{
 69	struct i2c_client *client = to_i2c_client(dev);
 70	struct cma3000_accl_data *data = i2c_get_clientdata(client);
 71
 72	cma3000_suspend(data);
 73
 74	return 0;
 75}
 76
 77static int cma3000_i2c_resume(struct device *dev)
 78{
 79	struct i2c_client *client = to_i2c_client(dev);
 80	struct cma3000_accl_data *data = i2c_get_clientdata(client);
 81
 82	cma3000_resume(data);
 83
 84	return 0;
 85}
 86
 87static const struct dev_pm_ops cma3000_i2c_pm_ops = {
 88	.suspend	= cma3000_i2c_suspend,
 89	.resume		= cma3000_i2c_resume,
 90};
 
 91
 92static const struct i2c_device_id cma3000_i2c_id[] = {
 93	{ "cma3000_d01", 0 },
 94	{ },
 95};
 96
 97MODULE_DEVICE_TABLE(i2c, cma3000_i2c_id);
 98
 99static struct i2c_driver cma3000_i2c_driver = {
100	.probe		= cma3000_i2c_probe,
101	.remove		= cma3000_i2c_remove,
102	.id_table	= cma3000_i2c_id,
103	.driver = {
104		.name	= "cma3000_i2c_accl",
105		.pm	= pm_sleep_ptr(&cma3000_i2c_pm_ops),
 
 
106	},
107};
108
109module_i2c_driver(cma3000_i2c_driver);
110
111MODULE_DESCRIPTION("CMA3000-D0x Accelerometer I2C Driver");
112MODULE_LICENSE("GPL");
113MODULE_AUTHOR("Hemanth V <hemanthv@ti.com>");
v4.6
 
  1/*
  2 * Implements I2C interface for VTI CMA300_D0x Accelerometer driver
  3 *
  4 * Copyright (C) 2010 Texas Instruments
  5 * Author: Hemanth V <hemanthv@ti.com>
  6 *
  7 * This program is free software; you can redistribute it and/or modify it
  8 * under the terms of the GNU General Public License version 2 as published by
  9 * the Free Software Foundation.
 10 *
 11 * This program is distributed in the hope that it will be useful, but WITHOUT
 12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 13 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 14 * more details.
 15 *
 16 * You should have received a copy of the GNU General Public License along with
 17 * this program.  If not, see <http://www.gnu.org/licenses/>.
 18 */
 19
 20#include <linux/module.h>
 21#include <linux/i2c.h>
 22#include <linux/input/cma3000.h>
 23#include "cma3000_d0x.h"
 24
 25static int cma3000_i2c_set(struct device *dev,
 26			   u8 reg, u8 val, char *msg)
 27{
 28	struct i2c_client *client = to_i2c_client(dev);
 29	int ret;
 30
 31	ret = i2c_smbus_write_byte_data(client, reg, val);
 32	if (ret < 0)
 33		dev_err(&client->dev,
 34			"%s failed (%s, %d)\n", __func__, msg, ret);
 35	return ret;
 36}
 37
 38static int cma3000_i2c_read(struct device *dev, u8 reg, char *msg)
 39{
 40	struct i2c_client *client = to_i2c_client(dev);
 41	int ret;
 42
 43	ret = i2c_smbus_read_byte_data(client, reg);
 44	if (ret < 0)
 45		dev_err(&client->dev,
 46			"%s failed (%s, %d)\n", __func__, msg, ret);
 47	return ret;
 48}
 49
 50static const struct cma3000_bus_ops cma3000_i2c_bops = {
 51	.bustype	= BUS_I2C,
 52#define CMA3000_BUSI2C     (0 << 4)
 53	.ctrl_mod	= CMA3000_BUSI2C,
 54	.read		= cma3000_i2c_read,
 55	.write		= cma3000_i2c_set,
 56};
 57
 58static int cma3000_i2c_probe(struct i2c_client *client,
 59					const struct i2c_device_id *id)
 60{
 61	struct cma3000_accl_data *data;
 62
 63	data = cma3000_init(&client->dev, client->irq, &cma3000_i2c_bops);
 64	if (IS_ERR(data))
 65		return PTR_ERR(data);
 66
 67	i2c_set_clientdata(client, data);
 68
 69	return 0;
 70}
 71
 72static int cma3000_i2c_remove(struct i2c_client *client)
 73{
 74	struct cma3000_accl_data *data = i2c_get_clientdata(client);
 75
 76	cma3000_exit(data);
 77
 78	return 0;
 79}
 80
 81#ifdef CONFIG_PM
 82static int cma3000_i2c_suspend(struct device *dev)
 83{
 84	struct i2c_client *client = to_i2c_client(dev);
 85	struct cma3000_accl_data *data = i2c_get_clientdata(client);
 86
 87	cma3000_suspend(data);
 88
 89	return 0;
 90}
 91
 92static int cma3000_i2c_resume(struct device *dev)
 93{
 94	struct i2c_client *client = to_i2c_client(dev);
 95	struct cma3000_accl_data *data = i2c_get_clientdata(client);
 96
 97	cma3000_resume(data);
 98
 99	return 0;
100}
101
102static const struct dev_pm_ops cma3000_i2c_pm_ops = {
103	.suspend	= cma3000_i2c_suspend,
104	.resume		= cma3000_i2c_resume,
105};
106#endif
107
108static const struct i2c_device_id cma3000_i2c_id[] = {
109	{ "cma3000_d01", 0 },
110	{ },
111};
112
113MODULE_DEVICE_TABLE(i2c, cma3000_i2c_id);
114
115static struct i2c_driver cma3000_i2c_driver = {
116	.probe		= cma3000_i2c_probe,
117	.remove		= cma3000_i2c_remove,
118	.id_table	= cma3000_i2c_id,
119	.driver = {
120		.name	= "cma3000_i2c_accl",
121#ifdef CONFIG_PM
122		.pm	= &cma3000_i2c_pm_ops,
123#endif
124	},
125};
126
127module_i2c_driver(cma3000_i2c_driver);
128
129MODULE_DESCRIPTION("CMA3000-D0x Accelerometer I2C Driver");
130MODULE_LICENSE("GPL");
131MODULE_AUTHOR("Hemanth V <hemanthv@ti.com>");