OpenCores
URL https://opencores.org/ocsvn/test_project/test_project/trunk

Subversion Repositories test_project

[/] [test_project/] [trunk/] [linux_sd_driver/] [include/] [sound/] [es1688.h] - Blame information for rev 62

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 62 marcus.erl
#ifndef __SOUND_ES1688_H
2
#define __SOUND_ES1688_H
3
 
4
/*
5
 *  Header file for ES488/ES1688
6
 *  Copyright (c) by Jaroslav Kysela <perex@perex.cz>
7
 *
8
 *
9
 *   This program is free software; you can redistribute it and/or modify
10
 *   it under the terms of the GNU General Public License as published by
11
 *   the Free Software Foundation; either version 2 of the License, or
12
 *   (at your option) any later version.
13
 *
14
 *   This program is distributed in the hope that it will be useful,
15
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 *   GNU General Public License for more details.
18
 *
19
 *   You should have received a copy of the GNU General Public License
20
 *   along with this program; if not, write to the Free Software
21
 *   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
22
 *
23
 */
24
 
25
#include "control.h"
26
#include "pcm.h"
27
#include <linux/interrupt.h>
28
 
29
#define ES1688_HW_AUTO          0x0000
30
#define ES1688_HW_688           0x0001
31
#define ES1688_HW_1688          0x0002
32
 
33
struct snd_es1688 {
34
        unsigned long port;             /* port of ESS chip */
35
        struct resource *res_port;
36
        unsigned long mpu_port;         /* MPU-401 port of ESS chip */
37
        int irq;                        /* IRQ number of ESS chip */
38
        int mpu_irq;                    /* MPU IRQ */
39
        int dma8;                       /* 8-bit DMA */
40
        unsigned short version;         /* version of ESS chip */
41
        unsigned short hardware;        /* see to ES1688_HW_XXXX */
42
 
43
        unsigned short trigger_value;
44
        unsigned char pad;
45
        unsigned int dma_size;
46
 
47
        struct snd_card *card;
48
        struct snd_pcm *pcm;
49
        struct snd_pcm_substream *playback_substream;
50
        struct snd_pcm_substream *capture_substream;
51
 
52
        spinlock_t reg_lock;
53
        spinlock_t mixer_lock;
54
};
55
 
56
/* I/O ports */
57
 
58
#define ES1688P(codec, x) ((codec)->port + e_s_s_ESS1688##x)
59
 
60
#define e_s_s_ESS1688RESET      0x6
61
#define e_s_s_ESS1688READ       0xa
62
#define e_s_s_ESS1688WRITE      0xc
63
#define e_s_s_ESS1688COMMAND    0xc
64
#define e_s_s_ESS1688STATUS     0xc
65
#define e_s_s_ESS1688DATA_AVAIL 0xe
66
#define e_s_s_ESS1688DATA_AVAIL_16 0xf
67
#define e_s_s_ESS1688MIXER_ADDR 0x4
68
#define e_s_s_ESS1688MIXER_DATA 0x5
69
#define e_s_s_ESS1688OPL3_LEFT  0x0
70
#define e_s_s_ESS1688OPL3_RIGHT 0x2
71
#define e_s_s_ESS1688OPL3_BOTH  0x8
72
#define e_s_s_ESS1688ENABLE0    0x0
73
#define e_s_s_ESS1688ENABLE1    0x9
74
#define e_s_s_ESS1688ENABLE2    0xb
75
#define e_s_s_ESS1688INIT1      0x7
76
 
77
#define ES1688_DSP_CMD_DMAOFF   0xd0
78
#define ES1688_DSP_CMD_SPKON    0xd1
79
#define ES1688_DSP_CMD_SPKOFF   0xd3
80
#define ES1688_DSP_CMD_DMAON    0xd4
81
 
82
#define ES1688_PCM_DEV          0x14
83
#define ES1688_MIC_DEV          0x1a
84
#define ES1688_REC_DEV          0x1c
85
#define ES1688_MASTER_DEV       0x32
86
#define ES1688_FM_DEV           0x36
87
#define ES1688_CD_DEV           0x38
88
#define ES1688_AUX_DEV          0x3a
89
#define ES1688_SPEAKER_DEV      0x3c
90
#define ES1688_LINE_DEV         0x3e
91
#define ES1688_RECLEV_DEV       0xb4
92
 
93
#define ES1688_MIXS_MASK        0x17
94
#define ES1688_MIXS_MIC         0x00
95
#define ES1688_MIXS_MIC_MASTER  0x01
96
#define ES1688_MIXS_CD          0x02
97
#define ES1688_MIXS_AOUT        0x03
98
#define ES1688_MIXS_MIC1        0x04
99
#define ES1688_MIXS_REC_MIX     0x05
100
#define ES1688_MIXS_LINE        0x06
101
#define ES1688_MIXS_MASTER      0x07
102
#define ES1688_MIXS_MUTE        0x10
103
 
104
/*
105
 
106
 */
107
 
108
void snd_es1688_mixer_write(struct snd_es1688 *chip, unsigned char reg, unsigned char data);
109
 
110
int snd_es1688_create(struct snd_card *card,
111
                      unsigned long port,
112
                      unsigned long mpu_port,
113
                      int irq,
114
                      int mpu_irq,
115
                      int dma8,
116
                      unsigned short hardware,
117
                      struct snd_es1688 ** rchip);
118
int snd_es1688_pcm(struct snd_es1688 *chip, int device, struct snd_pcm ** rpcm);
119
int snd_es1688_mixer(struct snd_es1688 *chip);
120
 
121
#endif /* __SOUND_ES1688_H */

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.