162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci//
362306a36Sopenharmony_ci// CS35l41 HDA SPI 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/spi/spi.h>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#include "cs35l41_hda.h"
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_cistatic int cs35l41_hda_spi_probe(struct spi_device *spi)
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(&spi->dev), "CSC3551"))
2462306a36Sopenharmony_ci		device_name = "CSC3551";
2562306a36Sopenharmony_ci	else
2662306a36Sopenharmony_ci		return -ENODEV;
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci	return cs35l41_hda_probe(&spi->dev, device_name, spi_get_chipselect(spi, 0), spi->irq,
2962306a36Sopenharmony_ci				 devm_regmap_init_spi(spi, &cs35l41_regmap_spi));
3062306a36Sopenharmony_ci}
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_cistatic void cs35l41_hda_spi_remove(struct spi_device *spi)
3362306a36Sopenharmony_ci{
3462306a36Sopenharmony_ci	cs35l41_hda_remove(&spi->dev);
3562306a36Sopenharmony_ci}
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_cistatic const struct spi_device_id cs35l41_hda_spi_id[] = {
3862306a36Sopenharmony_ci	{ "cs35l41-hda", 0 },
3962306a36Sopenharmony_ci	{}
4062306a36Sopenharmony_ci};
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_cistatic const struct acpi_device_id cs35l41_acpi_hda_match[] = {
4362306a36Sopenharmony_ci	{ "CSC3551", 0 },
4462306a36Sopenharmony_ci	{}
4562306a36Sopenharmony_ci};
4662306a36Sopenharmony_ciMODULE_DEVICE_TABLE(acpi, cs35l41_acpi_hda_match);
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_cistatic struct spi_driver cs35l41_spi_driver = {
4962306a36Sopenharmony_ci	.driver = {
5062306a36Sopenharmony_ci		.name		= "cs35l41-hda",
5162306a36Sopenharmony_ci		.acpi_match_table = cs35l41_acpi_hda_match,
5262306a36Sopenharmony_ci		.pm		= &cs35l41_hda_pm_ops,
5362306a36Sopenharmony_ci	},
5462306a36Sopenharmony_ci	.id_table	= cs35l41_hda_spi_id,
5562306a36Sopenharmony_ci	.probe		= cs35l41_hda_spi_probe,
5662306a36Sopenharmony_ci	.remove		= cs35l41_hda_spi_remove,
5762306a36Sopenharmony_ci};
5862306a36Sopenharmony_cimodule_spi_driver(cs35l41_spi_driver);
5962306a36Sopenharmony_ci
6062306a36Sopenharmony_ciMODULE_DESCRIPTION("HDA CS35L41 driver");
6162306a36Sopenharmony_ciMODULE_IMPORT_NS(SND_HDA_SCODEC_CS35L41);
6262306a36Sopenharmony_ciMODULE_AUTHOR("Lucas Tanure <tanureal@opensource.cirrus.com>");
6362306a36Sopenharmony_ciMODULE_LICENSE("GPL");
64