Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  1) // SPDX-License-Identifier: GPL-2.0-only
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  2) #include <linux/i2c.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  3) #include <linux/regmap.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  4) #include <linux/iio/iio.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  5) #include <linux/module.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  6) #include <linux/acpi.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  7) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  8) #include "bmg160.h"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  9) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) static const struct regmap_config bmg160_regmap_i2c_conf = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) 	.reg_bits = 8,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) 	.val_bits = 8,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) 	.max_register = 0x3f
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) static int bmg160_i2c_probe(struct i2c_client *client,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) 			    const struct i2c_device_id *id)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) 	struct regmap *regmap;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) 	const char *name = NULL;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) 	regmap = devm_regmap_init_i2c(client, &bmg160_regmap_i2c_conf);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) 	if (IS_ERR(regmap)) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) 		dev_err(&client->dev, "Failed to register i2c regmap: %pe\n",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) 			regmap);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) 		return PTR_ERR(regmap);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) 	}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) 	if (id)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) 		name = id->name;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) 	return bmg160_core_probe(&client->dev, regmap, client->irq, name);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) static int bmg160_i2c_remove(struct i2c_client *client)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) 	bmg160_core_remove(&client->dev);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) 	return 0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) static const struct acpi_device_id bmg160_acpi_match[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) 	{"BMG0160", 0},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) 	{"BMI055B", 0},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) 	{"BMI088B", 0},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) 	{},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) MODULE_DEVICE_TABLE(acpi, bmg160_acpi_match);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) static const struct i2c_device_id bmg160_i2c_id[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) 	{"bmg160", 0},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) 	{"bmi055_gyro", 0},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) 	{"bmi088_gyro", 0},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) 	{}
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) MODULE_DEVICE_TABLE(i2c, bmg160_i2c_id);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) static const struct of_device_id bmg160_of_match[] = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) 	{ .compatible = "bosch,bmg160" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) 	{ .compatible = "bosch,bmi055_gyro" },
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) 	{ }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 66) MODULE_DEVICE_TABLE(of, bmg160_of_match);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 67) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 68) static struct i2c_driver bmg160_i2c_driver = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 69) 	.driver = {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 70) 		.name	= "bmg160_i2c",
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 71) 		.acpi_match_table = ACPI_PTR(bmg160_acpi_match),
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 72) 		.of_match_table = bmg160_of_match,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 73) 		.pm	= &bmg160_pm_ops,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 74) 	},
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 75) 	.probe		= bmg160_i2c_probe,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 76) 	.remove		= bmg160_i2c_remove,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 77) 	.id_table	= bmg160_i2c_id,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 78) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 79) module_i2c_driver(bmg160_i2c_driver);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 80) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 81) MODULE_AUTHOR("Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>");
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 82) MODULE_LICENSE("GPL v2");
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 83) MODULE_DESCRIPTION("BMG160 I2C Gyro driver");