2019-05-27 13:55:05 +07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-04-17 05:20:36 +07:00
|
|
|
#ifndef __SOUND_SEQ_KERNEL_H
|
|
|
|
#define __SOUND_SEQ_KERNEL_H
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Main kernel header file for the ALSA sequencer
|
|
|
|
* Copyright (c) 1998 by Frank van de Pol <fvdpol@coil.demon.nl>
|
|
|
|
*/
|
|
|
|
#include <linux/time.h>
|
2012-10-03 00:01:25 +07:00
|
|
|
#include <sound/asequencer.h>
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2005-11-17 20:04:02 +07:00
|
|
|
typedef struct snd_seq_real_time snd_seq_real_time_t;
|
|
|
|
typedef union snd_seq_timestamp snd_seq_timestamp_t;
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* maximum number of queues */
|
2015-01-25 20:36:46 +07:00
|
|
|
#define SNDRV_SEQ_MAX_QUEUES 32
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* max number of concurrent clients */
|
|
|
|
#define SNDRV_SEQ_MAX_CLIENTS 192
|
|
|
|
|
|
|
|
/* max number of concurrent ports */
|
|
|
|
#define SNDRV_SEQ_MAX_PORTS 254
|
|
|
|
|
|
|
|
/* max number of events in memory pool */
|
|
|
|
#define SNDRV_SEQ_MAX_EVENTS 2000
|
|
|
|
|
|
|
|
/* default number of events in memory pool */
|
|
|
|
#define SNDRV_SEQ_DEFAULT_EVENTS 500
|
|
|
|
|
|
|
|
/* max number of events in memory pool for one client (outqueue) */
|
|
|
|
#define SNDRV_SEQ_MAX_CLIENT_EVENTS 2000
|
|
|
|
|
|
|
|
/* default number of events in memory pool for one client (outqueue) */
|
|
|
|
#define SNDRV_SEQ_DEFAULT_CLIENT_EVENTS 200
|
|
|
|
|
|
|
|
/* max delivery path length */
|
2017-11-07 02:16:50 +07:00
|
|
|
/* NOTE: this shouldn't be greater than MAX_LOCKDEP_SUBCLASSES */
|
|
|
|
#define SNDRV_SEQ_MAX_HOPS 8
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* max size of event size */
|
|
|
|
#define SNDRV_SEQ_MAX_EVENT_LEN 0x3fffffff
|
|
|
|
|
|
|
|
/* call-backs for kernel port */
|
2005-11-17 20:04:02 +07:00
|
|
|
struct snd_seq_port_callback {
|
2005-04-17 05:20:36 +07:00
|
|
|
struct module *owner;
|
|
|
|
void *private_data;
|
2005-11-17 20:04:02 +07:00
|
|
|
int (*subscribe)(void *private_data, struct snd_seq_port_subscribe *info);
|
|
|
|
int (*unsubscribe)(void *private_data, struct snd_seq_port_subscribe *info);
|
|
|
|
int (*use)(void *private_data, struct snd_seq_port_subscribe *info);
|
|
|
|
int (*unuse)(void *private_data, struct snd_seq_port_subscribe *info);
|
|
|
|
int (*event_input)(struct snd_seq_event *ev, int direct, void *private_data, int atomic, int hop);
|
|
|
|
void (*private_free)(void *private_data);
|
2005-04-17 05:20:36 +07:00
|
|
|
/*...*/
|
2005-11-17 20:04:02 +07:00
|
|
|
};
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* interface for kernel client */
|
2011-11-01 07:11:33 +07:00
|
|
|
__printf(3, 4)
|
2005-12-12 15:33:37 +07:00
|
|
|
int snd_seq_create_kernel_client(struct snd_card *card, int client_index,
|
2011-11-01 07:11:33 +07:00
|
|
|
const char *name_fmt, ...);
|
2005-11-17 20:04:02 +07:00
|
|
|
int snd_seq_delete_kernel_client(int client);
|
2019-04-12 17:10:14 +07:00
|
|
|
int snd_seq_kernel_client_enqueue(int client, struct snd_seq_event *ev,
|
|
|
|
struct file *file, bool blocking);
|
2005-11-17 20:04:02 +07:00
|
|
|
int snd_seq_kernel_client_dispatch(int client, struct snd_seq_event *ev, int atomic, int hop);
|
|
|
|
int snd_seq_kernel_client_ctl(int client, unsigned int cmd, void *arg);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
#define SNDRV_SEQ_EXT_MASK 0xc0000000
|
|
|
|
#define SNDRV_SEQ_EXT_USRPTR 0x80000000
|
|
|
|
#define SNDRV_SEQ_EXT_CHAINED 0x40000000
|
|
|
|
|
|
|
|
typedef int (*snd_seq_dump_func_t)(void *ptr, void *buf, int count);
|
2005-11-17 20:04:02 +07:00
|
|
|
int snd_seq_expand_var_event(const struct snd_seq_event *event, int count, char *buf,
|
|
|
|
int in_kernel, int size_aligned);
|
|
|
|
int snd_seq_dump_var_event(const struct snd_seq_event *event,
|
|
|
|
snd_seq_dump_func_t func, void *private_data);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* interface for OSS emulation */
|
2005-11-17 20:04:02 +07:00
|
|
|
int snd_seq_set_queue_tempo(int client, struct snd_seq_queue_tempo *tempo);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* port callback routines */
|
2005-11-17 20:04:02 +07:00
|
|
|
void snd_port_init_callback(struct snd_seq_port_callback *p);
|
|
|
|
struct snd_seq_port_callback *snd_port_alloc_callback(void);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* port attach/detach */
|
2005-11-17 20:04:02 +07:00
|
|
|
int snd_seq_event_port_attach(int client, struct snd_seq_port_callback *pcbp,
|
2005-04-17 05:20:36 +07:00
|
|
|
int cap, int type, int midi_channels, int midi_voices, char *portname);
|
|
|
|
int snd_seq_event_port_detach(int client, int port);
|
|
|
|
|
2008-07-09 15:28:41 +07:00
|
|
|
#ifdef CONFIG_MODULES
|
2014-10-15 19:06:25 +07:00
|
|
|
void snd_seq_autoload_init(void);
|
2015-02-12 20:20:24 +07:00
|
|
|
void snd_seq_autoload_exit(void);
|
2005-04-17 05:20:36 +07:00
|
|
|
#else
|
2014-10-15 19:06:25 +07:00
|
|
|
#define snd_seq_autoload_init()
|
|
|
|
#define snd_seq_autoload_exit()
|
2005-04-17 05:20:36 +07:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* __SOUND_SEQ_KERNEL_H */
|