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