162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci// ak4554.c
362306a36Sopenharmony_ci//
462306a36Sopenharmony_ci// Copyright (C) 2013 Renesas Solutions Corp.
562306a36Sopenharmony_ci// Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
662306a36Sopenharmony_ci
762306a36Sopenharmony_ci#include <linux/module.h>
862306a36Sopenharmony_ci#include <sound/soc.h>
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci/*
1162306a36Sopenharmony_ci * ak4554 is very simple DA/AD converter which has no setting register.
1262306a36Sopenharmony_ci *
1362306a36Sopenharmony_ci * CAUTION
1462306a36Sopenharmony_ci *
1562306a36Sopenharmony_ci * ak4554 playback format is SND_SOC_DAIFMT_RIGHT_J,
1662306a36Sopenharmony_ci * and,   capture  format is SND_SOC_DAIFMT_LEFT_J
1762306a36Sopenharmony_ci * on same bit clock, LR clock.
1862306a36Sopenharmony_ci * But, this driver doesn't have snd_soc_dai_ops :: set_fmt
1962306a36Sopenharmony_ci *
2062306a36Sopenharmony_ci * CPU/Codec DAI image
2162306a36Sopenharmony_ci *
2262306a36Sopenharmony_ci * CPU-DAI1 (plaback only fmt = RIGHT_J) --+-- ak4554
2362306a36Sopenharmony_ci *					   |
2462306a36Sopenharmony_ci * CPU-DAI2 (capture only fmt = LEFT_J) ---+
2562306a36Sopenharmony_ci */
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_cistatic const struct snd_soc_dapm_widget ak4554_dapm_widgets[] = {
2862306a36Sopenharmony_ciSND_SOC_DAPM_INPUT("AINL"),
2962306a36Sopenharmony_ciSND_SOC_DAPM_INPUT("AINR"),
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ciSND_SOC_DAPM_OUTPUT("AOUTL"),
3262306a36Sopenharmony_ciSND_SOC_DAPM_OUTPUT("AOUTR"),
3362306a36Sopenharmony_ci};
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_cistatic const struct snd_soc_dapm_route ak4554_dapm_routes[] = {
3662306a36Sopenharmony_ci	{ "Capture", NULL, "AINL" },
3762306a36Sopenharmony_ci	{ "Capture", NULL, "AINR" },
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci	{ "AOUTL", NULL, "Playback" },
4062306a36Sopenharmony_ci	{ "AOUTR", NULL, "Playback" },
4162306a36Sopenharmony_ci};
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_cistatic struct snd_soc_dai_driver ak4554_dai = {
4462306a36Sopenharmony_ci	.name = "ak4554-hifi",
4562306a36Sopenharmony_ci	.playback = {
4662306a36Sopenharmony_ci		.stream_name = "Playback",
4762306a36Sopenharmony_ci		.channels_min = 2,
4862306a36Sopenharmony_ci		.channels_max = 2,
4962306a36Sopenharmony_ci		.rates = SNDRV_PCM_RATE_8000_48000,
5062306a36Sopenharmony_ci		.formats = SNDRV_PCM_FMTBIT_S16_LE,
5162306a36Sopenharmony_ci	},
5262306a36Sopenharmony_ci	.capture = {
5362306a36Sopenharmony_ci		.stream_name = "Capture",
5462306a36Sopenharmony_ci		.channels_min = 2,
5562306a36Sopenharmony_ci		.channels_max = 2,
5662306a36Sopenharmony_ci		.rates = SNDRV_PCM_RATE_8000_48000,
5762306a36Sopenharmony_ci		.formats = SNDRV_PCM_FMTBIT_S16_LE,
5862306a36Sopenharmony_ci	},
5962306a36Sopenharmony_ci	.symmetric_rate = 1,
6062306a36Sopenharmony_ci};
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_cistatic const struct snd_soc_component_driver soc_component_dev_ak4554 = {
6362306a36Sopenharmony_ci	.dapm_widgets		= ak4554_dapm_widgets,
6462306a36Sopenharmony_ci	.num_dapm_widgets	= ARRAY_SIZE(ak4554_dapm_widgets),
6562306a36Sopenharmony_ci	.dapm_routes		= ak4554_dapm_routes,
6662306a36Sopenharmony_ci	.num_dapm_routes	= ARRAY_SIZE(ak4554_dapm_routes),
6762306a36Sopenharmony_ci	.idle_bias_on		= 1,
6862306a36Sopenharmony_ci	.use_pmdown_time	= 1,
6962306a36Sopenharmony_ci	.endianness		= 1,
7062306a36Sopenharmony_ci};
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_cistatic int ak4554_soc_probe(struct platform_device *pdev)
7362306a36Sopenharmony_ci{
7462306a36Sopenharmony_ci	return devm_snd_soc_register_component(&pdev->dev,
7562306a36Sopenharmony_ci				      &soc_component_dev_ak4554,
7662306a36Sopenharmony_ci				      &ak4554_dai, 1);
7762306a36Sopenharmony_ci}
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_cistatic const struct of_device_id ak4554_of_match[] = {
8062306a36Sopenharmony_ci	{ .compatible = "asahi-kasei,ak4554" },
8162306a36Sopenharmony_ci	{},
8262306a36Sopenharmony_ci};
8362306a36Sopenharmony_ciMODULE_DEVICE_TABLE(of, ak4554_of_match);
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_cistatic struct platform_driver ak4554_driver = {
8662306a36Sopenharmony_ci	.driver = {
8762306a36Sopenharmony_ci		.name = "ak4554-adc-dac",
8862306a36Sopenharmony_ci		.of_match_table = ak4554_of_match,
8962306a36Sopenharmony_ci	},
9062306a36Sopenharmony_ci	.probe	= ak4554_soc_probe,
9162306a36Sopenharmony_ci};
9262306a36Sopenharmony_cimodule_platform_driver(ak4554_driver);
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ciMODULE_LICENSE("GPL v2");
9562306a36Sopenharmony_ciMODULE_DESCRIPTION("SoC AK4554 driver");
9662306a36Sopenharmony_ciMODULE_AUTHOR("Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>");
97