1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */ 2*4882a593Smuzhiyun #ifndef __SOUND_EMUX_LEGACY_H 3*4882a593Smuzhiyun #define __SOUND_EMUX_LEGACY_H 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun /* 6*4882a593Smuzhiyun * Copyright (c) 1999-2000 Takashi Iwai <tiwai@suse.de> 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun * Definitions of OSS compatible headers for Emu8000 device informations 9*4882a593Smuzhiyun */ 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #include <sound/seq_oss_legacy.h> 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun /* 14*4882a593Smuzhiyun * awe hardware controls 15*4882a593Smuzhiyun */ 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun #define _EMUX_OSS_DEBUG_MODE 0x00 18*4882a593Smuzhiyun #define _EMUX_OSS_REVERB_MODE 0x01 19*4882a593Smuzhiyun #define _EMUX_OSS_CHORUS_MODE 0x02 20*4882a593Smuzhiyun #define _EMUX_OSS_REMOVE_LAST_SAMPLES 0x03 21*4882a593Smuzhiyun #define _EMUX_OSS_INITIALIZE_CHIP 0x04 22*4882a593Smuzhiyun #define _EMUX_OSS_SEND_EFFECT 0x05 23*4882a593Smuzhiyun #define _EMUX_OSS_TERMINATE_CHANNEL 0x06 24*4882a593Smuzhiyun #define _EMUX_OSS_TERMINATE_ALL 0x07 25*4882a593Smuzhiyun #define _EMUX_OSS_INITIAL_VOLUME 0x08 26*4882a593Smuzhiyun #define _EMUX_OSS_INITIAL_ATTEN _EMUX_OSS_INITIAL_VOLUME 27*4882a593Smuzhiyun #define _EMUX_OSS_RESET_CHANNEL 0x09 28*4882a593Smuzhiyun #define _EMUX_OSS_CHANNEL_MODE 0x0a 29*4882a593Smuzhiyun #define _EMUX_OSS_DRUM_CHANNELS 0x0b 30*4882a593Smuzhiyun #define _EMUX_OSS_MISC_MODE 0x0c 31*4882a593Smuzhiyun #define _EMUX_OSS_RELEASE_ALL 0x0d 32*4882a593Smuzhiyun #define _EMUX_OSS_NOTEOFF_ALL 0x0e 33*4882a593Smuzhiyun #define _EMUX_OSS_CHN_PRESSURE 0x0f 34*4882a593Smuzhiyun #define _EMUX_OSS_EQUALIZER 0x11 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun #define _EMUX_OSS_MODE_FLAG 0x80 37*4882a593Smuzhiyun #define _EMUX_OSS_COOKED_FLAG 0x40 /* not supported */ 38*4882a593Smuzhiyun #define _EMUX_OSS_MODE_VALUE_MASK 0x3F 39*4882a593Smuzhiyun 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun /* 42*4882a593Smuzhiyun * mode type definitions 43*4882a593Smuzhiyun */ 44*4882a593Smuzhiyun enum { 45*4882a593Smuzhiyun /* 0*/ EMUX_MD_EXCLUSIVE_OFF, /* obsolete */ 46*4882a593Smuzhiyun /* 1*/ EMUX_MD_EXCLUSIVE_ON, /* obsolete */ 47*4882a593Smuzhiyun /* 2*/ EMUX_MD_VERSION, /* read only */ 48*4882a593Smuzhiyun /* 3*/ EMUX_MD_EXCLUSIVE_SOUND, /* 0/1: exclusive note on (default=1) */ 49*4882a593Smuzhiyun /* 4*/ EMUX_MD_REALTIME_PAN, /* 0/1: do realtime pan change (default=1) */ 50*4882a593Smuzhiyun /* 5*/ EMUX_MD_GUS_BANK, /* bank number for GUS patches (default=0) */ 51*4882a593Smuzhiyun /* 6*/ EMUX_MD_KEEP_EFFECT, /* 0/1: keep effect values, (default=0) */ 52*4882a593Smuzhiyun /* 7*/ EMUX_MD_ZERO_ATTEN, /* attenuation of max volume (default=32) */ 53*4882a593Smuzhiyun /* 8*/ EMUX_MD_CHN_PRIOR, /* 0/1: set MIDI channel priority mode (default=1) */ 54*4882a593Smuzhiyun /* 9*/ EMUX_MD_MOD_SENSE, /* integer: modwheel sensitivity (def=18) */ 55*4882a593Smuzhiyun /*10*/ EMUX_MD_DEF_PRESET, /* integer: default preset number (def=0) */ 56*4882a593Smuzhiyun /*11*/ EMUX_MD_DEF_BANK, /* integer: default bank number (def=0) */ 57*4882a593Smuzhiyun /*12*/ EMUX_MD_DEF_DRUM, /* integer: default drumset number (def=0) */ 58*4882a593Smuzhiyun /*13*/ EMUX_MD_TOGGLE_DRUM_BANK, /* 0/1: toggle drum flag with bank# (def=0) */ 59*4882a593Smuzhiyun /*14*/ EMUX_MD_NEW_VOLUME_CALC, /* 0/1: volume calculation mode (def=1) */ 60*4882a593Smuzhiyun /*15*/ EMUX_MD_CHORUS_MODE, /* integer: chorus mode (def=2) */ 61*4882a593Smuzhiyun /*16*/ EMUX_MD_REVERB_MODE, /* integer: chorus mode (def=4) */ 62*4882a593Smuzhiyun /*17*/ EMUX_MD_BASS_LEVEL, /* integer: bass level (def=5) */ 63*4882a593Smuzhiyun /*18*/ EMUX_MD_TREBLE_LEVEL, /* integer: treble level (def=9) */ 64*4882a593Smuzhiyun /*19*/ EMUX_MD_DEBUG_MODE, /* integer: debug level (def=0) */ 65*4882a593Smuzhiyun /*20*/ EMUX_MD_PAN_EXCHANGE, /* 0/1: exchange panning direction (def=0) */ 66*4882a593Smuzhiyun EMUX_MD_END, 67*4882a593Smuzhiyun }; 68*4882a593Smuzhiyun 69*4882a593Smuzhiyun 70*4882a593Smuzhiyun /* 71*4882a593Smuzhiyun * effect parameters 72*4882a593Smuzhiyun */ 73*4882a593Smuzhiyun enum { 74*4882a593Smuzhiyun 75*4882a593Smuzhiyun /* modulation envelope parameters */ 76*4882a593Smuzhiyun /* 0*/ EMUX_FX_ENV1_DELAY, /* WORD: ENVVAL */ 77*4882a593Smuzhiyun /* 1*/ EMUX_FX_ENV1_ATTACK, /* BYTE: up ATKHLD */ 78*4882a593Smuzhiyun /* 2*/ EMUX_FX_ENV1_HOLD, /* BYTE: lw ATKHLD */ 79*4882a593Smuzhiyun /* 3*/ EMUX_FX_ENV1_DECAY, /* BYTE: lw DCYSUS */ 80*4882a593Smuzhiyun /* 4*/ EMUX_FX_ENV1_RELEASE, /* BYTE: lw DCYSUS */ 81*4882a593Smuzhiyun /* 5*/ EMUX_FX_ENV1_SUSTAIN, /* BYTE: up DCYSUS */ 82*4882a593Smuzhiyun /* 6*/ EMUX_FX_ENV1_PITCH, /* BYTE: up PEFE */ 83*4882a593Smuzhiyun /* 7*/ EMUX_FX_ENV1_CUTOFF, /* BYTE: lw PEFE */ 84*4882a593Smuzhiyun 85*4882a593Smuzhiyun /* volume envelope parameters */ 86*4882a593Smuzhiyun /* 8*/ EMUX_FX_ENV2_DELAY, /* WORD: ENVVOL */ 87*4882a593Smuzhiyun /* 9*/ EMUX_FX_ENV2_ATTACK, /* BYTE: up ATKHLDV */ 88*4882a593Smuzhiyun /*10*/ EMUX_FX_ENV2_HOLD, /* BYTE: lw ATKHLDV */ 89*4882a593Smuzhiyun /*11*/ EMUX_FX_ENV2_DECAY, /* BYTE: lw DCYSUSV */ 90*4882a593Smuzhiyun /*12*/ EMUX_FX_ENV2_RELEASE, /* BYTE: lw DCYSUSV */ 91*4882a593Smuzhiyun /*13*/ EMUX_FX_ENV2_SUSTAIN, /* BYTE: up DCYSUSV */ 92*4882a593Smuzhiyun 93*4882a593Smuzhiyun /* LFO1 (tremolo & vibrato) parameters */ 94*4882a593Smuzhiyun /*14*/ EMUX_FX_LFO1_DELAY, /* WORD: LFO1VAL */ 95*4882a593Smuzhiyun /*15*/ EMUX_FX_LFO1_FREQ, /* BYTE: lo TREMFRQ */ 96*4882a593Smuzhiyun /*16*/ EMUX_FX_LFO1_VOLUME, /* BYTE: up TREMFRQ */ 97*4882a593Smuzhiyun /*17*/ EMUX_FX_LFO1_PITCH, /* BYTE: up FMMOD */ 98*4882a593Smuzhiyun /*18*/ EMUX_FX_LFO1_CUTOFF, /* BYTE: lo FMMOD */ 99*4882a593Smuzhiyun 100*4882a593Smuzhiyun /* LFO2 (vibrato) parameters */ 101*4882a593Smuzhiyun /*19*/ EMUX_FX_LFO2_DELAY, /* WORD: LFO2VAL */ 102*4882a593Smuzhiyun /*20*/ EMUX_FX_LFO2_FREQ, /* BYTE: lo FM2FRQ2 */ 103*4882a593Smuzhiyun /*21*/ EMUX_FX_LFO2_PITCH, /* BYTE: up FM2FRQ2 */ 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun /* Other overall effect parameters */ 106*4882a593Smuzhiyun /*22*/ EMUX_FX_INIT_PITCH, /* SHORT: pitch offset */ 107*4882a593Smuzhiyun /*23*/ EMUX_FX_CHORUS, /* BYTE: chorus effects send (0-255) */ 108*4882a593Smuzhiyun /*24*/ EMUX_FX_REVERB, /* BYTE: reverb effects send (0-255) */ 109*4882a593Smuzhiyun /*25*/ EMUX_FX_CUTOFF, /* BYTE: up IFATN */ 110*4882a593Smuzhiyun /*26*/ EMUX_FX_FILTERQ, /* BYTE: up CCCA */ 111*4882a593Smuzhiyun 112*4882a593Smuzhiyun /* Sample / loop offset changes */ 113*4882a593Smuzhiyun /*27*/ EMUX_FX_SAMPLE_START, /* SHORT: offset */ 114*4882a593Smuzhiyun /*28*/ EMUX_FX_LOOP_START, /* SHORT: offset */ 115*4882a593Smuzhiyun /*29*/ EMUX_FX_LOOP_END, /* SHORT: offset */ 116*4882a593Smuzhiyun /*30*/ EMUX_FX_COARSE_SAMPLE_START, /* SHORT: upper word offset */ 117*4882a593Smuzhiyun /*31*/ EMUX_FX_COARSE_LOOP_START, /* SHORT: upper word offset */ 118*4882a593Smuzhiyun /*32*/ EMUX_FX_COARSE_LOOP_END, /* SHORT: upper word offset */ 119*4882a593Smuzhiyun /*33*/ EMUX_FX_ATTEN, /* BYTE: lo IFATN */ 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun EMUX_FX_END, 122*4882a593Smuzhiyun }; 123*4882a593Smuzhiyun /* number of effects */ 124*4882a593Smuzhiyun #define EMUX_NUM_EFFECTS EMUX_FX_END 125*4882a593Smuzhiyun 126*4882a593Smuzhiyun /* effect flag values */ 127*4882a593Smuzhiyun #define EMUX_FX_FLAG_OFF 0 128*4882a593Smuzhiyun #define EMUX_FX_FLAG_SET 1 129*4882a593Smuzhiyun #define EMUX_FX_FLAG_ADD 2 130*4882a593Smuzhiyun 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun #endif /* __SOUND_EMUX_LEGACY_H */ 133