mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-04 19:54:03 +08:00
75b1a8f9d6
strlcpy is deprecated. see: Documentation/process/deprecated.rst Change the calls that do not use the strlcpy return value to the preferred strscpy. Done with cocci script: @@ expression e1, e2, e3; @@ - strlcpy( + strscpy( e1, e2, e3); This cocci script leaves the instances where the return value is used unchanged. After this patch, sound/ has 3 uses of strlcpy() that need to be manually inspected for conversion and changed one day. $ git grep -w strlcpy sound/ sound/usb/card.c: len = strlcpy(card->longname, s, sizeof(card->longname)); sound/usb/mixer.c: return strlcpy(buf, p->name, buflen); sound/usb/mixer.c: return strlcpy(buf, p->names[index], buflen); Miscellenea: o Remove trailing whitespace in conversion of sound/core/hwdep.c Link: https://lore.kernel.org/lkml/CAHk-=wgfRnXz0W3D37d01q3JFkr_i_uTL=V6A6G1oUZcprmknw@mail.gmail.com/ Signed-off-by: Joe Perches <joe@perches.com> Acked-by: Mark Brown <broonie@kernel.org> Link: https://lore.kernel.org/r/22b393d1790bb268769d0bab7bacf0866dcb0c14.camel@perches.com Signed-off-by: Takashi Iwai <tiwai@suse.de>
150 lines
3.3 KiB
C
150 lines
3.3 KiB
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* Apple Onboard Audio driver for Toonie codec
|
|
*
|
|
* Copyright 2006 Johannes Berg <johannes@sipsolutions.net>
|
|
*
|
|
* This is a driver for the toonie codec chip. This chip is present
|
|
* on the Mac Mini and is nothing but a DAC.
|
|
*/
|
|
#include <linux/delay.h>
|
|
#include <linux/module.h>
|
|
#include <linux/slab.h>
|
|
MODULE_AUTHOR("Johannes Berg <johannes@sipsolutions.net>");
|
|
MODULE_LICENSE("GPL");
|
|
MODULE_DESCRIPTION("toonie codec driver for snd-aoa");
|
|
|
|
#include "../aoa.h"
|
|
#include "../soundbus/soundbus.h"
|
|
|
|
|
|
#define PFX "snd-aoa-codec-toonie: "
|
|
|
|
struct toonie {
|
|
struct aoa_codec codec;
|
|
};
|
|
#define codec_to_toonie(c) container_of(c, struct toonie, codec)
|
|
|
|
static int toonie_dev_register(struct snd_device *dev)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static const struct snd_device_ops ops = {
|
|
.dev_register = toonie_dev_register,
|
|
};
|
|
|
|
static struct transfer_info toonie_transfers[] = {
|
|
/* This thing *only* has analog output,
|
|
* the rates are taken from Info.plist
|
|
* from Darwin. */
|
|
{
|
|
.formats = SNDRV_PCM_FMTBIT_S16_BE |
|
|
SNDRV_PCM_FMTBIT_S24_BE,
|
|
.rates = SNDRV_PCM_RATE_32000 |
|
|
SNDRV_PCM_RATE_44100 |
|
|
SNDRV_PCM_RATE_48000 |
|
|
SNDRV_PCM_RATE_88200 |
|
|
SNDRV_PCM_RATE_96000,
|
|
},
|
|
{}
|
|
};
|
|
|
|
static int toonie_usable(struct codec_info_item *cii,
|
|
struct transfer_info *ti,
|
|
struct transfer_info *out)
|
|
{
|
|
return 1;
|
|
}
|
|
|
|
#ifdef CONFIG_PM
|
|
static int toonie_suspend(struct codec_info_item *cii, pm_message_t state)
|
|
{
|
|
/* can we turn it off somehow? */
|
|
return 0;
|
|
}
|
|
|
|
static int toonie_resume(struct codec_info_item *cii)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif /* CONFIG_PM */
|
|
|
|
static struct codec_info toonie_codec_info = {
|
|
.transfers = toonie_transfers,
|
|
.sysclock_factor = 256,
|
|
.bus_factor = 64,
|
|
.owner = THIS_MODULE,
|
|
.usable = toonie_usable,
|
|
#ifdef CONFIG_PM
|
|
.suspend = toonie_suspend,
|
|
.resume = toonie_resume,
|
|
#endif
|
|
};
|
|
|
|
static int toonie_init_codec(struct aoa_codec *codec)
|
|
{
|
|
struct toonie *toonie = codec_to_toonie(codec);
|
|
|
|
/* nothing connected? what a joke! */
|
|
if (toonie->codec.connected != 1)
|
|
return -ENOTCONN;
|
|
|
|
if (aoa_snd_device_new(SNDRV_DEV_CODEC, toonie, &ops)) {
|
|
printk(KERN_ERR PFX "failed to create toonie snd device!\n");
|
|
return -ENODEV;
|
|
}
|
|
|
|
if (toonie->codec.soundbus_dev->attach_codec(toonie->codec.soundbus_dev,
|
|
aoa_get_card(),
|
|
&toonie_codec_info, toonie)) {
|
|
printk(KERN_ERR PFX "error creating toonie pcm\n");
|
|
snd_device_free(aoa_get_card(), toonie);
|
|
return -ENODEV;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void toonie_exit_codec(struct aoa_codec *codec)
|
|
{
|
|
struct toonie *toonie = codec_to_toonie(codec);
|
|
|
|
if (!toonie->codec.soundbus_dev) {
|
|
printk(KERN_ERR PFX "toonie_exit_codec called without soundbus_dev!\n");
|
|
return;
|
|
}
|
|
toonie->codec.soundbus_dev->detach_codec(toonie->codec.soundbus_dev, toonie);
|
|
}
|
|
|
|
static struct toonie *toonie;
|
|
|
|
static int __init toonie_init(void)
|
|
{
|
|
toonie = kzalloc(sizeof(struct toonie), GFP_KERNEL);
|
|
|
|
if (!toonie)
|
|
return -ENOMEM;
|
|
|
|
strscpy(toonie->codec.name, "toonie", sizeof(toonie->codec.name));
|
|
toonie->codec.owner = THIS_MODULE;
|
|
toonie->codec.init = toonie_init_codec;
|
|
toonie->codec.exit = toonie_exit_codec;
|
|
|
|
if (aoa_codec_register(&toonie->codec)) {
|
|
kfree(toonie);
|
|
return -EINVAL;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static void __exit toonie_exit(void)
|
|
{
|
|
aoa_codec_unregister(&toonie->codec);
|
|
kfree(toonie);
|
|
}
|
|
|
|
module_init(toonie_init);
|
|
module_exit(toonie_exit);
|