162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci// 362306a36Sopenharmony_ci// CS35l41 HDA I2C driver 462306a36Sopenharmony_ci// 562306a36Sopenharmony_ci// Copyright 2021 Cirrus Logic, Inc. 662306a36Sopenharmony_ci// 762306a36Sopenharmony_ci// Author: Lucas Tanure <tanureal@opensource.cirrus.com> 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#include <linux/mod_devicetable.h> 1062306a36Sopenharmony_ci#include <linux/module.h> 1162306a36Sopenharmony_ci#include <linux/i2c.h> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#include "cs35l41_hda.h" 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_cistatic int cs35l41_hda_i2c_probe(struct i2c_client *clt) 1662306a36Sopenharmony_ci{ 1762306a36Sopenharmony_ci const char *device_name; 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci /* 2062306a36Sopenharmony_ci * Compare against the device name so it works for SPI, normal ACPI 2162306a36Sopenharmony_ci * and for ACPI by serial-multi-instantiate matching cases. 2262306a36Sopenharmony_ci */ 2362306a36Sopenharmony_ci if (strstr(dev_name(&clt->dev), "CLSA0100")) 2462306a36Sopenharmony_ci device_name = "CLSA0100"; 2562306a36Sopenharmony_ci else if (strstr(dev_name(&clt->dev), "CLSA0101")) 2662306a36Sopenharmony_ci device_name = "CLSA0101"; 2762306a36Sopenharmony_ci else if (strstr(dev_name(&clt->dev), "CSC3551")) 2862306a36Sopenharmony_ci device_name = "CSC3551"; 2962306a36Sopenharmony_ci else 3062306a36Sopenharmony_ci return -ENODEV; 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_ci return cs35l41_hda_probe(&clt->dev, device_name, clt->addr, clt->irq, 3362306a36Sopenharmony_ci devm_regmap_init_i2c(clt, &cs35l41_regmap_i2c)); 3462306a36Sopenharmony_ci} 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_cistatic void cs35l41_hda_i2c_remove(struct i2c_client *clt) 3762306a36Sopenharmony_ci{ 3862306a36Sopenharmony_ci cs35l41_hda_remove(&clt->dev); 3962306a36Sopenharmony_ci} 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_cistatic const struct i2c_device_id cs35l41_hda_i2c_id[] = { 4262306a36Sopenharmony_ci { "cs35l41-hda", 0 }, 4362306a36Sopenharmony_ci {} 4462306a36Sopenharmony_ci}; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_cistatic const struct acpi_device_id cs35l41_acpi_hda_match[] = { 4762306a36Sopenharmony_ci {"CLSA0100", 0 }, 4862306a36Sopenharmony_ci {"CLSA0101", 0 }, 4962306a36Sopenharmony_ci {"CSC3551", 0 }, 5062306a36Sopenharmony_ci {} 5162306a36Sopenharmony_ci}; 5262306a36Sopenharmony_ciMODULE_DEVICE_TABLE(acpi, cs35l41_acpi_hda_match); 5362306a36Sopenharmony_ci 5462306a36Sopenharmony_cistatic struct i2c_driver cs35l41_i2c_driver = { 5562306a36Sopenharmony_ci .driver = { 5662306a36Sopenharmony_ci .name = "cs35l41-hda", 5762306a36Sopenharmony_ci .acpi_match_table = cs35l41_acpi_hda_match, 5862306a36Sopenharmony_ci .pm = &cs35l41_hda_pm_ops, 5962306a36Sopenharmony_ci }, 6062306a36Sopenharmony_ci .id_table = cs35l41_hda_i2c_id, 6162306a36Sopenharmony_ci .probe = cs35l41_hda_i2c_probe, 6262306a36Sopenharmony_ci .remove = cs35l41_hda_i2c_remove, 6362306a36Sopenharmony_ci}; 6462306a36Sopenharmony_cimodule_i2c_driver(cs35l41_i2c_driver); 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ciMODULE_DESCRIPTION("HDA CS35L41 driver"); 6762306a36Sopenharmony_ciMODULE_IMPORT_NS(SND_HDA_SCODEC_CS35L41); 6862306a36Sopenharmony_ciMODULE_AUTHOR("Lucas Tanure <tanureal@opensource.cirrus.com>"); 6962306a36Sopenharmony_ciMODULE_LICENSE("GPL"); 70