forked from Minki/linux
1a59d1b8e0
Based on 1 normalized pattern(s): this program is free software you can redistribute it and or modify it under the terms of the gnu general public license as published by the free software foundation either version 2 of the license or at your option any later version this program is distributed in the hope that it will be useful but without any warranty without even the implied warranty of merchantability or fitness for a particular purpose see the gnu general public license for more details you should have received a copy of the gnu general public license along with this program if not write to the free software foundation inc 59 temple place suite 330 boston ma 02111 1307 usa extracted by the scancode license scanner the SPDX license identifier GPL-2.0-or-later has been chosen to replace the boilerplate/reference in 1334 file(s). Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Reviewed-by: Allison Randal <allison@lohutok.net> Reviewed-by: Richard Fontana <rfontana@redhat.com> Cc: linux-spdx@vger.kernel.org Link: https://lkml.kernel.org/r/20190527070033.113240726@linutronix.de Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
70 lines
2.1 KiB
C
70 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
#ifndef __SOUND_SEQ_VIRMIDI_H
|
|
#define __SOUND_SEQ_VIRMIDI_H
|
|
|
|
/*
|
|
* Virtual Raw MIDI client on Sequencer
|
|
* Copyright (c) 2000 by Takashi Iwai <tiwai@suse.de>,
|
|
* Jaroslav Kysela <perex@perex.cz>
|
|
*/
|
|
|
|
#include <sound/rawmidi.h>
|
|
#include <sound/seq_midi_event.h>
|
|
|
|
/*
|
|
* device file instance:
|
|
* This instance is created at each time the midi device file is
|
|
* opened. Each instance has its own input buffer and MIDI parser
|
|
* (buffer), and is associated with the device instance.
|
|
*/
|
|
struct snd_virmidi {
|
|
struct list_head list;
|
|
int seq_mode;
|
|
int client;
|
|
int port;
|
|
bool trigger;
|
|
struct snd_midi_event *parser;
|
|
struct snd_seq_event event;
|
|
struct snd_virmidi_dev *rdev;
|
|
struct snd_rawmidi_substream *substream;
|
|
struct work_struct output_work;
|
|
};
|
|
|
|
#define SNDRV_VIRMIDI_SUBSCRIBE (1<<0)
|
|
#define SNDRV_VIRMIDI_USE (1<<1)
|
|
|
|
/*
|
|
* device record:
|
|
* Each virtual midi device has one device instance. It contains
|
|
* common information and the linked-list of opened files,
|
|
*/
|
|
struct snd_virmidi_dev {
|
|
struct snd_card *card; /* associated card */
|
|
struct snd_rawmidi *rmidi; /* rawmidi device */
|
|
int seq_mode; /* SNDRV_VIRMIDI_XXX */
|
|
int device; /* sequencer device */
|
|
int client; /* created/attached client */
|
|
int port; /* created/attached port */
|
|
unsigned int flags; /* SNDRV_VIRMIDI_* */
|
|
rwlock_t filelist_lock;
|
|
struct rw_semaphore filelist_sem;
|
|
struct list_head filelist;
|
|
};
|
|
|
|
/* sequencer mode:
|
|
* ATTACH = input/output events from midi device are routed to the
|
|
* attached sequencer port. sequencer port is not created
|
|
* by virmidi itself.
|
|
* the input to rawmidi must be processed by passing the
|
|
* incoming events via snd_virmidi_receive()
|
|
* DISPATCH = input/output events are routed to subscribers.
|
|
* sequencer port is created in virmidi.
|
|
*/
|
|
#define SNDRV_VIRMIDI_SEQ_NONE 0
|
|
#define SNDRV_VIRMIDI_SEQ_ATTACH 1
|
|
#define SNDRV_VIRMIDI_SEQ_DISPATCH 2
|
|
|
|
int snd_virmidi_new(struct snd_card *card, int device, struct snd_rawmidi **rrmidi);
|
|
|
|
#endif /* __SOUND_SEQ_VIRMIDI */
|