bmi160_i2c.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * BMI160 - Bosch IMU, I2C bits
  4. *
  5. * Copyright (c) 2016, Intel Corporation.
  6. *
  7. * 7-bit I2C slave address is:
  8. * - 0x68 if SDO is pulled to GND
  9. * - 0x69 if SDO is pulled to VDDIO
  10. */
  11. #include <linux/i2c.h>
  12. #include <linux/mod_devicetable.h>
  13. #include <linux/module.h>
  14. #include <linux/regmap.h>
  15. #include "bmi160.h"
  16. static int bmi160_i2c_probe(struct i2c_client *client)
  17. {
  18. const struct i2c_device_id *id = i2c_client_get_device_id(client);
  19. struct regmap *regmap;
  20. const char *name;
  21. regmap = devm_regmap_init_i2c(client, &bmi160_regmap_config);
  22. if (IS_ERR(regmap)) {
  23. dev_err(&client->dev, "Failed to register i2c regmap: %pe\n",
  24. regmap);
  25. return PTR_ERR(regmap);
  26. }
  27. if (id)
  28. name = id->name;
  29. else
  30. name = dev_name(&client->dev);
  31. return bmi160_core_probe(&client->dev, regmap, name, false);
  32. }
  33. static const struct i2c_device_id bmi160_i2c_id[] = {
  34. { "bmi120" },
  35. { "bmi160" },
  36. {}
  37. };
  38. MODULE_DEVICE_TABLE(i2c, bmi160_i2c_id);
  39. static const struct acpi_device_id bmi160_acpi_match[] = {
  40. /*
  41. * FIRMWARE BUG WORKAROUND
  42. * Some manufacturers like GPD, Lenovo or Aya used the incorrect
  43. * ID "10EC5280" for bmi160 in their DSDT. A fixed firmware is not
  44. * available as of Feb 2024 after trying to work with OEMs, and
  45. * this is not expected to change anymore since at least some of
  46. * the affected devices are from 2021/2022.
  47. */
  48. {"10EC5280", 0},
  49. {"BMI0120", 0},
  50. {"BMI0160", 0},
  51. { },
  52. };
  53. MODULE_DEVICE_TABLE(acpi, bmi160_acpi_match);
  54. static const struct of_device_id bmi160_of_match[] = {
  55. { .compatible = "bosch,bmi120" },
  56. { .compatible = "bosch,bmi160" },
  57. { },
  58. };
  59. MODULE_DEVICE_TABLE(of, bmi160_of_match);
  60. static struct i2c_driver bmi160_i2c_driver = {
  61. .driver = {
  62. .name = "bmi160_i2c",
  63. .acpi_match_table = bmi160_acpi_match,
  64. .of_match_table = bmi160_of_match,
  65. },
  66. .probe = bmi160_i2c_probe,
  67. .id_table = bmi160_i2c_id,
  68. };
  69. module_i2c_driver(bmi160_i2c_driver);
  70. MODULE_AUTHOR("Daniel Baluta <daniel.baluta@intel.com>");
  71. MODULE_DESCRIPTION("BMI160 I2C driver");
  72. MODULE_LICENSE("GPL v2");
  73. MODULE_IMPORT_NS(IIO_BMI160);