Changes in 5.15.63
ALSA: info: Fix llseek return value when using callback
ALSA: hda/realtek: Add quirk for Clevo NS50PU, NS70PU
KVM: Unconditionally get a ref to /dev/kvm module when creating a VM
x86/mm: Use proper mask when setting PUD mapping
rds: add missing barrier to release_refill
locking/atomic: Make test_and_*_bit() ordered on failure
drm/nouveau: recognise GA103
drm/ttm: Fix dummy res NULL ptr deref bug
drm/amd/display: Check correct bounds for stream encoder instances for DCN303
ata: libata-eh: Add missing command name
mmc: pxamci: Fix another error handling path in pxamci_probe()
mmc: pxamci: Fix an error handling path in pxamci_probe()
mmc: meson-gx: Fix an error handling path in meson_mmc_probe()
btrfs: unset reloc control if transaction commit fails in prepare_to_relocate()
btrfs: reset RO counter on block group if we fail to relocate
btrfs: fix lost error handling when looking up extended ref on log replay
cifs: Fix memory leak on the deferred close
x86/kprobes: Fix JNG/JNLE emulation
tracing/perf: Fix double put of trace event when init fails
tracing/eprobes: Do not allow eprobes to use $stack, or % for regs
tracing/eprobes: Do not hardcode $comm as a string
tracing/eprobes: Have event probes be consistent with kprobes and uprobes
tracing/probes: Have kprobes and uprobes use $COMM too
tracing: Have filter accept "common_cpu" to be consistent
ALSA: usb-audio: More comprehensive mixer map for ASUS ROG Zenith II
dt-bindings: usb: mtk-xhci: Allow wakeup interrupt-names to be optional
can: ems_usb: fix clang's -Wunaligned-access warning
apparmor: fix quiet_denied for file rules
apparmor: fix absroot causing audited secids to begin with =
apparmor: Fix failed mount permission check error message
apparmor: fix aa_label_asxprint return check
apparmor: fix setting unconfined mode on a loaded profile
apparmor: fix overlapping attachment computation
apparmor: fix reference count leak in aa_pivotroot()
apparmor: Fix memleak in aa_simple_write_to_buffer()
Documentation: ACPI: EINJ: Fix obsolete example
NFSv4.1: Don't decrease the value of seq_nr_highest_sent
NFSv4.1: Handle NFS4ERR_DELAY replies to OP_SEQUENCE correctly
NFSv4: Fix races in the legacy idmapper upcall
NFSv4.1: RECLAIM_COMPLETE must handle EACCES
NFSv4/pnfs: Fix a use-after-free bug in open
BPF: Fix potential bad pointer dereference in bpf_sys_bpf()
bpf: Don't reinit map value in prealloc_lru_pop
bpf: Acquire map uref in .init_seq_private for array map iterator
bpf: Acquire map uref in .init_seq_private for hash map iterator
bpf: Acquire map uref in .init_seq_private for sock local storage map iterator
bpf: Acquire map uref in .init_seq_private for sock{map,hash} iterator
bpf: Check the validity of max_rdwr_access for sock local storage map iterator
can: mcp251x: Fix race condition on receive interrupt
can: j1939: j1939_session_destroy(): fix memory leak of skbs
net: atlantic: fix aq_vec index out of range error
m68k: coldfire/device.c: protect FLEXCAN blocks
sunrpc: fix expiry of auth creds
SUNRPC: Fix xdr_encode_bool()
SUNRPC: Reinitialise the backchannel request buffers before reuse
virtio_net: fix memory leak inside XPD_TX with mergeable
devlink: Fix use-after-free after a failed reload
net: phy: Warn about incorrect mdio_bus_phy_resume() state
net: bcmgenet: Indicate MAC is in charge of PHY PM
net: bgmac: Fix a BUG triggered by wrong bytes_compl
selftests: forwarding: Fix failing tests with old libnet
dt-bindings: arm: qcom: fix Alcatel OneTouch Idol 3 compatibles
pinctrl: nomadik: Fix refcount leak in nmk_pinctrl_dt_subnode_to_map
pinctrl: qcom: msm8916: Allow CAMSS GP clocks to be muxed
pinctrl: amd: Don't save/restore interrupt status and wake status bits
pinctrl: sunxi: Add I/O bias setting for H6 R-PIO
pinctrl: qcom: sm8250: Fix PDC map
Input: exc3000 - fix return value check of wait_for_completion_timeout
octeontx2-pf: Fix NIX_AF_TL3_TL2X_LINKX_CFG register configuration
octeontx2-af: Apply tx nibble fixup always
octeontx2-af: suppress external profile loading warning
octeontx2-af: Fix mcam entry resource leak
octeontx2-af: Fix key checking for source mac
ACPI: property: Return type of acpi_add_nondev_subnodes() should be bool
geneve: do not use RT_TOS for IPv6 flowlabel
mlx5: do not use RT_TOS for IPv6 flowlabel
ipv6: do not use RT_TOS for IPv6 flowlabel
plip: avoid rcu debug splat
vsock: Fix memory leak in vsock_connect()
vsock: Set socket state back to SS_UNCONNECTED in vsock_connect_timeout()
dt-bindings: gpio: zynq: Add missing compatible strings
dt-bindings: arm: qcom: fix Longcheer L8150 compatibles
dt-bindings: arm: qcom: fix MSM8916 MTP compatibles
dt-bindings: arm: qcom: fix MSM8994 boards compatibles
dt-bindings: clock: qcom,gcc-msm8996: add more GCC clock sources
spi: dt-bindings: cadence: add missing 'required'
spi: dt-bindings: zynqmp-qspi: add missing 'required'
ceph: use correct index when encoding client supported features
tools/vm/slabinfo: use alphabetic order when two values are equal
ceph: don't leak snap_rwsem in handle_cap_grant
kbuild: dummy-tools: avoid tmpdir leak in dummy gcc
tools build: Switch to new openssl API for test-libcrypto
NTB: ntb_tool: uninitialized heap data in tool_fn_write()
nfp: ethtool: fix the display error of `ethtool -m DEVNAME`
xen/xenbus: fix return type in xenbus_file_read()
atm: idt77252: fix use-after-free bugs caused by tst_timer
geneve: fix TOS inheriting for ipv4
perf probe: Fix an error handling path in 'parse_perf_probe_command()'
perf parse-events: Fix segfault when event parser gets an error
perf tests: Fix Track with sched_switch test for hybrid case
dpaa2-eth: trace the allocated address instead of page struct
fs/ntfs3: Fix using uninitialized value n when calling indx_read
fs/ntfs3: Fix NULL deref in ntfs_update_mftmirr
fs/ntfs3: Don't clear upper bits accidentally in log_replay()
fs/ntfs3: Fix double free on remount
fs/ntfs3: Do not change mode if ntfs_set_ea failed
fs/ntfs3: Fix missing i_op in ntfs_read_mft
nios2: page fault et.al. are *not* restartable syscalls...
nios2: don't leave NULLs in sys_call_table[]
nios2: traced syscall does need to check the syscall number
nios2: fix syscall restart checks
nios2: restarts apply only to the first sigframe we build...
nios2: add force_successful_syscall_return()
iavf: Fix adminq error handling
iavf: Fix reset error handling
ASoC: SOF: debug: Fix potential buffer overflow by snprintf()
ASoC: tas2770: Set correct FSYNC polarity
ASoC: tas2770: Allow mono streams
ASoC: tas2770: Drop conflicting set_bias_level power setting
ASoC: tas2770: Fix handling of mute/unmute
ASoC: codec: tlv320aic32x4: fix mono playback via I2S
netfilter: nf_tables: use READ_ONCE and WRITE_ONCE for shared generation id access
fs/ntfs3: uninitialized variable in ntfs_set_acl_ex()
netfilter: nf_tables: disallow NFTA_SET_ELEM_KEY_END with NFT_SET_ELEM_INTERVAL_END flag
netfilter: nf_tables: possible module reference underflow in error path
netfilter: nf_tables: really skip inactive sets when allocating name
netfilter: nf_tables: validate NFTA_SET_ELEM_OBJREF based on NFT_SET_OBJECT flag
netfilter: nf_tables: NFTA_SET_ELEM_KEY_END requires concat and interval flags
netfilter: nf_tables: disallow NFT_SET_ELEM_CATCHALL and NFT_SET_ELEM_INTERVAL_END
netfilter: nf_tables: check NFT_SET_CONCAT flag if field_count is specified
powerpc/pci: Fix get_phb_number() locking
spi: meson-spicc: add local pow2 clock ops to preserve rate between messages
net/sunrpc: fix potential memory leaks in rpc_sysfs_xprt_state_change()
net: dsa: mv88e6060: prevent crash on an unused port
mlxsw: spectrum: Clear PTP configuration after unregistering the netdevice
net: moxa: pass pdev instead of ndev to DMA functions
net: fix potential refcount leak in ndisc_router_discovery()
net: dsa: microchip: ksz9477: fix fdb_dump last invalid entry
net: dsa: felix: fix ethtool 256-511 and 512-1023 TX packet counters
net: genl: fix error path memory leak in policy dumping
net: dsa: don't warn in dsa_port_set_state_now() when driver doesn't support it
net: dsa: sja1105: fix buffer overflow in sja1105_setup_devlink_regions()
ice: Ignore EEXIST when setting promisc mode
i2c: imx: Make sure to unregister adapter on remove()
regulator: pca9450: Remove restrictions for regulator-name
i40e: Fix to stop tx_timeout recovery if GLOBR fails
fec: Fix timer capture timing in `fec_ptp_enable_pps()`
stmmac: intel: Add a missing clk_disable_unprepare() call in intel_eth_pci_remove()
igb: Add lock to avoid data race
kbuild: fix the modules order between drivers and libs
gcc-plugins: Undefine LATENT_ENTROPY_PLUGIN when plugin disabled for a file
tracing/eprobes: Fix reading of string fields
drm/imx/dcss: get rid of HPD warning message
ASoC: SOF: Intel: hda: Define rom_status_reg in sof_intel_dsp_desc
ASoC: SOF: Intel: hda: Fix potential buffer overflow by snprintf()
drm/meson: Fix refcount bugs in meson_vpu_has_available_connectors()
drm/sun4i: dsi: Prevent underflow when computing packet sizes
net: qrtr: start MHI channel after endpoit creation
KVM: arm64: Treat PMCR_EL1.LC as RES1 on asymmetric systems
KVM: arm64: Reject 32bit user PSTATE on asymmetric systems
HID: multitouch: new device class fix Lenovo X12 trackpad sticky
PCI: Add ACS quirk for Broadcom BCM5750x NICs
platform/chrome: cros_ec_proto: don't show MKBP version if unsupported
usb: cdns3 fix use-after-free at workaround 2
usb: cdns3: fix random warning message when driver load
usb: gadget: uvc: calculate the number of request depending on framesize
usb: gadget: uvc: call uvc uvcg_warn on completed status instead of uvcg_info
PCI: aardvark: Fix reporting Slot capabilities on emulated bridge
irqchip/tegra: Fix overflow implicit truncation warnings
drm/meson: Fix overflow implicit truncation warnings
clk: ti: Stop using legacy clkctrl names for omap4 and 5
scsi: ufs: ufs-mediatek: Fix the timing of configuring device regulators
usb: host: ohci-ppc-of: Fix refcount leak bug
usb: renesas: Fix refcount leak bug
usb: dwc2: gadget: remove D+ pull-up while no vbus with usb-role-switch
vboxguest: Do not use devm for irq
clk: qcom: ipq8074: dont disable gcc_sleep_clk_src
uacce: Handle parent device removal or parent driver module rmmod
zram: do not lookup algorithm in backends table
clk: qcom: clk-alpha-pll: fix clk_trion_pll_configure description
scsi: lpfc: Prevent buffer overflow crashes in debugfs with malformed user input
scsi: lpfc: Fix possible memory leak when failing to issue CMF WQE
gadgetfs: ep_io - wait until IRQ finishes
coresight: etm4x: avoid build failure with unrolled loops
habanalabs/gaudi: fix shift out of bounds
habanalabs/gaudi: mask constant value before cast
mmc: tmio: avoid glitches when resetting
pinctrl: intel: Check against matching data instead of ACPI companion
cxl: Fix a memory leak in an error handling path
PCI/ACPI: Guard ARM64-specific mcfg_quirks
um: add "noreboot" command line option for PANIC_TIMEOUT=-1 setups
dmaengine: dw-axi-dmac: do not print NULL LLI during error
dmaengine: dw-axi-dmac: ignore interrupt if no descriptor
RDMA/rxe: Limit the number of calls to each tasklet
csky/kprobe: reclaim insn_slot on kprobe unregistration
selftests/kprobe: Do not test for GRP/ without event failures
dmaengine: sprd: Cleanup in .remove() after pm_runtime_get_sync() failed
openrisc: io: Define iounmap argument as volatile
phy: samsung: phy-exynos-pcie: sanitize init/power_on callbacks
md: Notify sysfs sync_completed in md_reap_sync_thread()
nvmet-tcp: fix lockdep complaint on nvmet_tcp_wq flush during queue teardown
drivers:md:fix a potential use-after-free bug
ext4: avoid remove directory when directory is corrupted
ext4: avoid resizing to a partial cluster size
lib/list_debug.c: Detect uninitialized lists
tty: serial: Fix refcount leak bug in ucc_uart.c
KVM: PPC: Book3S HV: Fix "rm_exit" entry in debugfs timings
vfio: Clear the caps->buf to NULL after free
mips: cavium-octeon: Fix missing of_node_put() in octeon2_usb_clocks_start
iommu/io-pgtable-arm-v7s: Add a quirk to allow pgtable PA up to 35bit
modules: Ensure natural alignment for .altinstructions and __bug_table sections
ASoC: rsnd: care default case on rsnd_ssiu_busif_err_irq_ctrl()
riscv: dts: sifive: Add fu740 topology information
riscv: dts: canaan: Add k210 topology information
riscv: mmap with PROT_WRITE but no PROT_READ is invalid
RISC-V: Add fast call path of crash_kexec()
watchdog: export lockup_detector_reconfigure
powerpc/32: Set an IBAT covering up to _einittext during init
powerpc/32: Don't always pass -mcpu=powerpc to the compiler
ovl: warn if trusted xattr creation fails
powerpc/ioda/iommu/debugfs: Generate unique debugfs entries
ALSA: core: Add async signal helpers
ALSA: timer: Use deferred fasync helper
ALSA: control: Use deferred fasync helper
f2fs: fix to avoid use f2fs_bug_on() in f2fs_new_node_page()
f2fs: fix to do sanity check on segment type in build_sit_entries()
smb3: check xattr value length earlier
powerpc/64: Init jump labels before parse_early_param()
venus: pm_helpers: Fix warning in OPP during probe
video: fbdev: i740fb: Check the argument of i740_calc_vclk()
MIPS: tlbex: Explicitly compare _PAGE_NO_EXEC against 0
can: j1939: j1939_sk_queue_activate_next_locked(): replace WARN_ON_ONCE with netdev_warn_once()
scsi: ufs: ufs-mediatek: Fix build error and type mismatch
xfs: flush inodegc workqueue tasks before cancel
xfs: reserve quota for dir expansion when linking/unlinking files
xfs: reserve quota for target dir expansion when renaming files
xfs: remove infinite loop when reserving free block pool
xfs: always succeed at setting the reserve pool size
xfs: fix overfilling of reserve pool
xfs: fix soft lockup via spinning in filestream ag selection loop
xfs: revert "xfs: actually bump warning counts when we send warnings"
xfs: reject crazy array sizes being fed to XFS_IOC_GETBMAP*
Linux 5.15.63
Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
Change-Id: I85d0cf74054be9e400907eac7d8f2d4d85914f6f
529 lines
16 KiB
C
529 lines
16 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
#ifndef __SOUND_CORE_H
|
|
#define __SOUND_CORE_H
|
|
|
|
/*
|
|
* Main header file for the ALSA driver
|
|
* Copyright (c) 1994-2001 by Jaroslav Kysela <perex@perex.cz>
|
|
*/
|
|
|
|
#include <linux/device.h>
|
|
#include <linux/sched.h> /* wake_up() */
|
|
#include <linux/mutex.h> /* struct mutex */
|
|
#include <linux/rwsem.h> /* struct rw_semaphore */
|
|
#include <linux/pm.h> /* pm_message_t */
|
|
#include <linux/stringify.h>
|
|
#include <linux/printk.h>
|
|
#include <linux/android_kabi.h>
|
|
#include <linux/xarray.h>
|
|
|
|
/* number of supported soundcards */
|
|
#ifdef CONFIG_SND_DYNAMIC_MINORS
|
|
#define SNDRV_CARDS CONFIG_SND_MAX_CARDS
|
|
#else
|
|
#define SNDRV_CARDS 8 /* don't change - minor numbers */
|
|
#endif
|
|
|
|
#define CONFIG_SND_MAJOR 116 /* standard configuration */
|
|
|
|
/* forward declarations */
|
|
struct pci_dev;
|
|
struct module;
|
|
struct completion;
|
|
|
|
/* device allocation stuff */
|
|
|
|
/* type of the object used in snd_device_*()
|
|
* this also defines the calling order
|
|
*/
|
|
enum snd_device_type {
|
|
SNDRV_DEV_LOWLEVEL,
|
|
SNDRV_DEV_INFO,
|
|
SNDRV_DEV_BUS,
|
|
SNDRV_DEV_CODEC,
|
|
SNDRV_DEV_PCM,
|
|
SNDRV_DEV_COMPRESS,
|
|
SNDRV_DEV_RAWMIDI,
|
|
SNDRV_DEV_TIMER,
|
|
SNDRV_DEV_SEQUENCER,
|
|
SNDRV_DEV_HWDEP,
|
|
SNDRV_DEV_JACK,
|
|
SNDRV_DEV_CONTROL, /* NOTE: this must be the last one */
|
|
};
|
|
|
|
enum snd_device_state {
|
|
SNDRV_DEV_BUILD,
|
|
SNDRV_DEV_REGISTERED,
|
|
SNDRV_DEV_DISCONNECTED,
|
|
};
|
|
|
|
struct snd_device;
|
|
|
|
struct snd_device_ops {
|
|
int (*dev_free)(struct snd_device *dev);
|
|
int (*dev_register)(struct snd_device *dev);
|
|
int (*dev_disconnect)(struct snd_device *dev);
|
|
|
|
ANDROID_KABI_RESERVE(1);
|
|
};
|
|
|
|
struct snd_device {
|
|
struct list_head list; /* list of registered devices */
|
|
struct snd_card *card; /* card which holds this device */
|
|
enum snd_device_state state; /* state of the device */
|
|
enum snd_device_type type; /* device type */
|
|
void *device_data; /* device structure */
|
|
const struct snd_device_ops *ops; /* operations */
|
|
|
|
ANDROID_KABI_RESERVE(1);
|
|
};
|
|
|
|
#define snd_device(n) list_entry(n, struct snd_device, list)
|
|
|
|
/* main structure for soundcard */
|
|
|
|
struct snd_card {
|
|
int number; /* number of soundcard (index to
|
|
snd_cards) */
|
|
|
|
char id[16]; /* id string of this card */
|
|
char driver[16]; /* driver name */
|
|
char shortname[32]; /* short name of this soundcard */
|
|
char longname[80]; /* name of this soundcard */
|
|
char irq_descr[32]; /* Interrupt description */
|
|
char mixername[80]; /* mixer name */
|
|
char components[128]; /* card components delimited with
|
|
space */
|
|
struct module *module; /* top-level module */
|
|
|
|
void *private_data; /* private data for soundcard */
|
|
void (*private_free) (struct snd_card *card); /* callback for freeing of
|
|
private data */
|
|
struct list_head devices; /* devices */
|
|
|
|
struct device ctl_dev; /* control device */
|
|
unsigned int last_numid; /* last used numeric ID */
|
|
struct rw_semaphore controls_rwsem; /* controls list lock */
|
|
rwlock_t ctl_files_rwlock; /* ctl_files list lock */
|
|
int controls_count; /* count of all controls */
|
|
size_t user_ctl_alloc_size; // current memory allocation by user controls.
|
|
struct list_head controls; /* all controls for this card */
|
|
struct list_head ctl_files; /* active control files */
|
|
#ifdef CONFIG_SND_CTL_FAST_LOOKUP
|
|
struct xarray ctl_numids; /* hash table for numids */
|
|
struct xarray ctl_hash; /* hash table for ctl id matching */
|
|
bool ctl_hash_collision; /* ctl_hash collision seen? */
|
|
#endif
|
|
|
|
struct snd_info_entry *proc_root; /* root for soundcard specific files */
|
|
struct proc_dir_entry *proc_root_link; /* number link to real id */
|
|
|
|
struct list_head files_list; /* all files associated to this card */
|
|
struct snd_shutdown_f_ops *s_f_ops; /* file operations in the shutdown
|
|
state */
|
|
spinlock_t files_lock; /* lock the files for this card */
|
|
int shutdown; /* this card is going down */
|
|
struct completion *release_completion;
|
|
struct device *dev; /* device assigned to this card */
|
|
struct device card_dev; /* cardX object for sysfs */
|
|
const struct attribute_group *dev_groups[4]; /* assigned sysfs attr */
|
|
bool registered; /* card_dev is registered? */
|
|
bool managed; /* managed via devres */
|
|
bool releasing; /* during card free process */
|
|
int sync_irq; /* assigned irq, used for PCM sync */
|
|
wait_queue_head_t remove_sleep;
|
|
|
|
size_t total_pcm_alloc_bytes; /* total amount of allocated buffers */
|
|
struct mutex memory_mutex; /* protection for the above */
|
|
#ifdef CONFIG_SND_DEBUG
|
|
struct dentry *debugfs_root; /* debugfs root for card */
|
|
#endif
|
|
|
|
#ifdef CONFIG_PM
|
|
unsigned int power_state; /* power state */
|
|
atomic_t power_ref;
|
|
wait_queue_head_t power_sleep;
|
|
wait_queue_head_t power_ref_sleep;
|
|
#endif
|
|
|
|
#if IS_ENABLED(CONFIG_SND_MIXER_OSS)
|
|
struct snd_mixer_oss *mixer_oss;
|
|
int mixer_oss_change_count;
|
|
#endif
|
|
|
|
ANDROID_KABI_RESERVE(1);
|
|
ANDROID_KABI_RESERVE(2);
|
|
};
|
|
|
|
#define dev_to_snd_card(p) container_of(p, struct snd_card, card_dev)
|
|
|
|
#ifdef CONFIG_PM
|
|
static inline unsigned int snd_power_get_state(struct snd_card *card)
|
|
{
|
|
return READ_ONCE(card->power_state);
|
|
}
|
|
|
|
static inline void snd_power_change_state(struct snd_card *card, unsigned int state)
|
|
{
|
|
WRITE_ONCE(card->power_state, state);
|
|
wake_up(&card->power_sleep);
|
|
}
|
|
|
|
/**
|
|
* snd_power_ref - Take the reference count for power control
|
|
* @card: sound card object
|
|
*
|
|
* The power_ref reference of the card is used for managing to block
|
|
* the snd_power_sync_ref() operation. This function increments the reference.
|
|
* The counterpart snd_power_unref() has to be called appropriately later.
|
|
*/
|
|
static inline void snd_power_ref(struct snd_card *card)
|
|
{
|
|
atomic_inc(&card->power_ref);
|
|
}
|
|
|
|
/**
|
|
* snd_power_unref - Release the reference count for power control
|
|
* @card: sound card object
|
|
*/
|
|
static inline void snd_power_unref(struct snd_card *card)
|
|
{
|
|
if (atomic_dec_and_test(&card->power_ref))
|
|
wake_up(&card->power_ref_sleep);
|
|
}
|
|
|
|
/**
|
|
* snd_power_sync_ref - wait until the card power_ref is freed
|
|
* @card: sound card object
|
|
*
|
|
* This function is used to synchronize with the pending power_ref being
|
|
* released.
|
|
*/
|
|
static inline void snd_power_sync_ref(struct snd_card *card)
|
|
{
|
|
wait_event(card->power_ref_sleep, !atomic_read(&card->power_ref));
|
|
}
|
|
|
|
/* init.c */
|
|
int snd_power_wait(struct snd_card *card);
|
|
int snd_power_ref_and_wait(struct snd_card *card);
|
|
|
|
#else /* ! CONFIG_PM */
|
|
|
|
static inline int snd_power_wait(struct snd_card *card) { return 0; }
|
|
static inline void snd_power_ref(struct snd_card *card) {}
|
|
static inline void snd_power_unref(struct snd_card *card) {}
|
|
static inline int snd_power_ref_and_wait(struct snd_card *card) { return 0; }
|
|
static inline void snd_power_sync_ref(struct snd_card *card) {}
|
|
#define snd_power_get_state(card) ({ (void)(card); SNDRV_CTL_POWER_D0; })
|
|
#define snd_power_change_state(card, state) do { (void)(card); } while (0)
|
|
|
|
#endif /* CONFIG_PM */
|
|
|
|
struct snd_minor {
|
|
int type; /* SNDRV_DEVICE_TYPE_XXX */
|
|
int card; /* card number */
|
|
int device; /* device number */
|
|
const struct file_operations *f_ops; /* file operations */
|
|
void *private_data; /* private data for f_ops->open */
|
|
struct device *dev; /* device for sysfs */
|
|
struct snd_card *card_ptr; /* assigned card instance */
|
|
|
|
ANDROID_KABI_RESERVE(1);
|
|
};
|
|
|
|
/* return a device pointer linked to each sound device as a parent */
|
|
static inline struct device *snd_card_get_device_link(struct snd_card *card)
|
|
{
|
|
return card ? &card->card_dev : NULL;
|
|
}
|
|
|
|
/* sound.c */
|
|
|
|
extern int snd_major;
|
|
extern int snd_ecards_limit;
|
|
extern struct class *sound_class;
|
|
#ifdef CONFIG_SND_DEBUG
|
|
extern struct dentry *sound_debugfs_root;
|
|
#endif
|
|
|
|
void snd_request_card(int card);
|
|
|
|
void snd_device_initialize(struct device *dev, struct snd_card *card);
|
|
|
|
int snd_register_device(int type, struct snd_card *card, int dev,
|
|
const struct file_operations *f_ops,
|
|
void *private_data, struct device *device);
|
|
int snd_unregister_device(struct device *dev);
|
|
void *snd_lookup_minor_data(unsigned int minor, int type);
|
|
|
|
#ifdef CONFIG_SND_OSSEMUL
|
|
int snd_register_oss_device(int type, struct snd_card *card, int dev,
|
|
const struct file_operations *f_ops, void *private_data);
|
|
int snd_unregister_oss_device(int type, struct snd_card *card, int dev);
|
|
void *snd_lookup_oss_minor_data(unsigned int minor, int type);
|
|
#endif
|
|
|
|
int snd_minor_info_init(void);
|
|
|
|
/* sound_oss.c */
|
|
|
|
#ifdef CONFIG_SND_OSSEMUL
|
|
int snd_minor_info_oss_init(void);
|
|
#else
|
|
static inline int snd_minor_info_oss_init(void) { return 0; }
|
|
#endif
|
|
|
|
/* memory.c */
|
|
|
|
int copy_to_user_fromio(void __user *dst, const volatile void __iomem *src, size_t count);
|
|
int copy_from_user_toio(volatile void __iomem *dst, const void __user *src, size_t count);
|
|
|
|
/* init.c */
|
|
|
|
int snd_card_locked(int card);
|
|
#if IS_ENABLED(CONFIG_SND_MIXER_OSS)
|
|
#define SND_MIXER_OSS_NOTIFY_REGISTER 0
|
|
#define SND_MIXER_OSS_NOTIFY_DISCONNECT 1
|
|
#define SND_MIXER_OSS_NOTIFY_FREE 2
|
|
extern int (*snd_mixer_oss_notify_callback)(struct snd_card *card, int cmd);
|
|
#endif
|
|
|
|
int snd_card_new(struct device *parent, int idx, const char *xid,
|
|
struct module *module, int extra_size,
|
|
struct snd_card **card_ret);
|
|
int snd_devm_card_new(struct device *parent, int idx, const char *xid,
|
|
struct module *module, size_t extra_size,
|
|
struct snd_card **card_ret);
|
|
|
|
int snd_card_disconnect(struct snd_card *card);
|
|
void snd_card_disconnect_sync(struct snd_card *card);
|
|
int snd_card_free(struct snd_card *card);
|
|
int snd_card_free_when_closed(struct snd_card *card);
|
|
int snd_card_free_on_error(struct device *dev, int ret);
|
|
void snd_card_set_id(struct snd_card *card, const char *id);
|
|
int snd_card_register(struct snd_card *card);
|
|
int snd_card_info_init(void);
|
|
int snd_card_add_dev_attr(struct snd_card *card,
|
|
const struct attribute_group *group);
|
|
int snd_component_add(struct snd_card *card, const char *component);
|
|
int snd_card_file_add(struct snd_card *card, struct file *file);
|
|
int snd_card_file_remove(struct snd_card *card, struct file *file);
|
|
|
|
struct snd_card *snd_card_ref(int card);
|
|
|
|
/**
|
|
* snd_card_unref - Unreference the card object
|
|
* @card: the card object to unreference
|
|
*
|
|
* Call this function for the card object that was obtained via snd_card_ref()
|
|
* or snd_lookup_minor_data().
|
|
*/
|
|
static inline void snd_card_unref(struct snd_card *card)
|
|
{
|
|
put_device(&card->card_dev);
|
|
}
|
|
|
|
#define snd_card_set_dev(card, devptr) ((card)->dev = (devptr))
|
|
|
|
/* device.c */
|
|
|
|
int snd_device_new(struct snd_card *card, enum snd_device_type type,
|
|
void *device_data, const struct snd_device_ops *ops);
|
|
int snd_device_register(struct snd_card *card, void *device_data);
|
|
int snd_device_register_all(struct snd_card *card);
|
|
void snd_device_disconnect(struct snd_card *card, void *device_data);
|
|
void snd_device_disconnect_all(struct snd_card *card);
|
|
void snd_device_free(struct snd_card *card, void *device_data);
|
|
void snd_device_free_all(struct snd_card *card);
|
|
int snd_device_get_state(struct snd_card *card, void *device_data);
|
|
|
|
/* isadma.c */
|
|
|
|
#ifdef CONFIG_ISA_DMA_API
|
|
#define DMA_MODE_NO_ENABLE 0x0100
|
|
|
|
void snd_dma_program(unsigned long dma, unsigned long addr, unsigned int size, unsigned short mode);
|
|
void snd_dma_disable(unsigned long dma);
|
|
unsigned int snd_dma_pointer(unsigned long dma, unsigned int size);
|
|
int snd_devm_request_dma(struct device *dev, int dma, const char *name);
|
|
#endif
|
|
|
|
/* misc.c */
|
|
struct resource;
|
|
void release_and_free_resource(struct resource *res);
|
|
|
|
/* --- */
|
|
|
|
/* sound printk debug levels */
|
|
enum {
|
|
SND_PR_ALWAYS,
|
|
SND_PR_DEBUG,
|
|
SND_PR_VERBOSE,
|
|
};
|
|
|
|
#if defined(CONFIG_SND_DEBUG) || defined(CONFIG_SND_VERBOSE_PRINTK)
|
|
__printf(4, 5)
|
|
void __snd_printk(unsigned int level, const char *file, int line,
|
|
const char *format, ...);
|
|
#else
|
|
#define __snd_printk(level, file, line, format, ...) \
|
|
printk(format, ##__VA_ARGS__)
|
|
#endif
|
|
|
|
/**
|
|
* snd_printk - printk wrapper
|
|
* @fmt: format string
|
|
*
|
|
* Works like printk() but prints the file and the line of the caller
|
|
* when configured with CONFIG_SND_VERBOSE_PRINTK.
|
|
*/
|
|
#define snd_printk(fmt, ...) \
|
|
__snd_printk(0, __FILE__, __LINE__, fmt, ##__VA_ARGS__)
|
|
|
|
#ifdef CONFIG_SND_DEBUG
|
|
/**
|
|
* snd_printd - debug printk
|
|
* @fmt: format string
|
|
*
|
|
* Works like snd_printk() for debugging purposes.
|
|
* Ignored when CONFIG_SND_DEBUG is not set.
|
|
*/
|
|
#define snd_printd(fmt, ...) \
|
|
__snd_printk(1, __FILE__, __LINE__, fmt, ##__VA_ARGS__)
|
|
#define _snd_printd(level, fmt, ...) \
|
|
__snd_printk(level, __FILE__, __LINE__, fmt, ##__VA_ARGS__)
|
|
|
|
/**
|
|
* snd_BUG - give a BUG warning message and stack trace
|
|
*
|
|
* Calls WARN() if CONFIG_SND_DEBUG is set.
|
|
* Ignored when CONFIG_SND_DEBUG is not set.
|
|
*/
|
|
#define snd_BUG() WARN(1, "BUG?\n")
|
|
|
|
/**
|
|
* snd_printd_ratelimit - Suppress high rates of output when
|
|
* CONFIG_SND_DEBUG is enabled.
|
|
*/
|
|
#define snd_printd_ratelimit() printk_ratelimit()
|
|
|
|
/**
|
|
* snd_BUG_ON - debugging check macro
|
|
* @cond: condition to evaluate
|
|
*
|
|
* Has the same behavior as WARN_ON when CONFIG_SND_DEBUG is set,
|
|
* otherwise just evaluates the conditional and returns the value.
|
|
*/
|
|
#define snd_BUG_ON(cond) WARN_ON((cond))
|
|
|
|
#else /* !CONFIG_SND_DEBUG */
|
|
|
|
__printf(1, 2)
|
|
static inline void snd_printd(const char *format, ...) {}
|
|
__printf(2, 3)
|
|
static inline void _snd_printd(int level, const char *format, ...) {}
|
|
|
|
#define snd_BUG() do { } while (0)
|
|
|
|
#define snd_BUG_ON(condition) ({ \
|
|
int __ret_warn_on = !!(condition); \
|
|
unlikely(__ret_warn_on); \
|
|
})
|
|
|
|
static inline bool snd_printd_ratelimit(void) { return false; }
|
|
|
|
#endif /* CONFIG_SND_DEBUG */
|
|
|
|
#ifdef CONFIG_SND_DEBUG_VERBOSE
|
|
/**
|
|
* snd_printdd - debug printk
|
|
* @format: format string
|
|
*
|
|
* Works like snd_printk() for debugging purposes.
|
|
* Ignored when CONFIG_SND_DEBUG_VERBOSE is not set.
|
|
*/
|
|
#define snd_printdd(format, ...) \
|
|
__snd_printk(2, __FILE__, __LINE__, format, ##__VA_ARGS__)
|
|
#else
|
|
__printf(1, 2)
|
|
static inline void snd_printdd(const char *format, ...) {}
|
|
#endif
|
|
|
|
|
|
#define SNDRV_OSS_VERSION ((3<<16)|(8<<8)|(1<<4)|(0)) /* 3.8.1a */
|
|
|
|
/* for easier backward-porting */
|
|
#if IS_ENABLED(CONFIG_GAMEPORT)
|
|
#define gameport_set_dev_parent(gp,xdev) ((gp)->dev.parent = (xdev))
|
|
#define gameport_set_port_data(gp,r) ((gp)->port_data = (r))
|
|
#define gameport_get_port_data(gp) (gp)->port_data
|
|
#endif
|
|
|
|
/* PCI quirk list helper */
|
|
struct snd_pci_quirk {
|
|
unsigned short subvendor; /* PCI subvendor ID */
|
|
unsigned short subdevice; /* PCI subdevice ID */
|
|
unsigned short subdevice_mask; /* bitmask to match */
|
|
int value; /* value */
|
|
#ifdef CONFIG_SND_DEBUG_VERBOSE
|
|
const char *name; /* name of the device (optional) */
|
|
#endif
|
|
};
|
|
|
|
#define _SND_PCI_QUIRK_ID_MASK(vend, mask, dev) \
|
|
.subvendor = (vend), .subdevice = (dev), .subdevice_mask = (mask)
|
|
#define _SND_PCI_QUIRK_ID(vend, dev) \
|
|
_SND_PCI_QUIRK_ID_MASK(vend, 0xffff, dev)
|
|
#define SND_PCI_QUIRK_ID(vend,dev) {_SND_PCI_QUIRK_ID(vend, dev)}
|
|
#ifdef CONFIG_SND_DEBUG_VERBOSE
|
|
#define SND_PCI_QUIRK(vend,dev,xname,val) \
|
|
{_SND_PCI_QUIRK_ID(vend, dev), .value = (val), .name = (xname)}
|
|
#define SND_PCI_QUIRK_VENDOR(vend, xname, val) \
|
|
{_SND_PCI_QUIRK_ID_MASK(vend, 0, 0), .value = (val), .name = (xname)}
|
|
#define SND_PCI_QUIRK_MASK(vend, mask, dev, xname, val) \
|
|
{_SND_PCI_QUIRK_ID_MASK(vend, mask, dev), \
|
|
.value = (val), .name = (xname)}
|
|
#define snd_pci_quirk_name(q) ((q)->name)
|
|
#else
|
|
#define SND_PCI_QUIRK(vend,dev,xname,val) \
|
|
{_SND_PCI_QUIRK_ID(vend, dev), .value = (val)}
|
|
#define SND_PCI_QUIRK_MASK(vend, mask, dev, xname, val) \
|
|
{_SND_PCI_QUIRK_ID_MASK(vend, mask, dev), .value = (val)}
|
|
#define SND_PCI_QUIRK_VENDOR(vend, xname, val) \
|
|
{_SND_PCI_QUIRK_ID_MASK(vend, 0, 0), .value = (val)}
|
|
#define snd_pci_quirk_name(q) ""
|
|
#endif
|
|
|
|
#ifdef CONFIG_PCI
|
|
const struct snd_pci_quirk *
|
|
snd_pci_quirk_lookup(struct pci_dev *pci, const struct snd_pci_quirk *list);
|
|
|
|
const struct snd_pci_quirk *
|
|
snd_pci_quirk_lookup_id(u16 vendor, u16 device,
|
|
const struct snd_pci_quirk *list);
|
|
#else
|
|
static inline const struct snd_pci_quirk *
|
|
snd_pci_quirk_lookup(struct pci_dev *pci, const struct snd_pci_quirk *list)
|
|
{
|
|
return NULL;
|
|
}
|
|
|
|
static inline const struct snd_pci_quirk *
|
|
snd_pci_quirk_lookup_id(u16 vendor, u16 device,
|
|
const struct snd_pci_quirk *list)
|
|
{
|
|
return NULL;
|
|
}
|
|
#endif
|
|
|
|
/* async signal helpers */
|
|
struct snd_fasync;
|
|
|
|
int snd_fasync_helper(int fd, struct file *file, int on,
|
|
struct snd_fasync **fasyncp);
|
|
void snd_kill_fasync(struct snd_fasync *fasync, int signal, int poll);
|
|
void snd_fasync_free(struct snd_fasync *fasync);
|
|
|
|
#endif /* __SOUND_CORE_H */
|