Commit 6b75a9d8 authored by Takashi Iwai's avatar Takashi Iwai Committed by Jaroslav Kysela

[ALSA] Remove xxx_t typedefs: PCI Intel8x0

Modules: Intel8x0 driver,Intel8x0-modem driver

Remove xxx_t typedefs from the PCI Intel8x0 and modem drivers.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent a5f22156
...@@ -272,7 +272,8 @@ enum { ...@@ -272,7 +272,8 @@ enum {
#define ALI_INT_CPRAIS (1<<7) /* command port available */ #define ALI_INT_CPRAIS (1<<7) /* command port available */
#define ALI_INT_SPRAIS (1<<5) /* status port available */ #define ALI_INT_SPRAIS (1<<5) /* status port available */
#define ALI_INT_GPIO (1<<1) #define ALI_INT_GPIO (1<<1)
#define ALI_INT_MASK (ALI_INT_SPDIFOUT|ALI_INT_CODECSPDIFOUT|ALI_INT_MICIN|ALI_INT_PCMOUT|ALI_INT_PCMIN) #define ALI_INT_MASK (ALI_INT_SPDIFOUT|ALI_INT_CODECSPDIFOUT|\
ALI_INT_MICIN|ALI_INT_PCMOUT|ALI_INT_PCMIN)
#define ICH_ALI_SC_RESET (1<<31) /* master reset */ #define ICH_ALI_SC_RESET (1<<31) /* master reset */
#define ICH_ALI_SC_AC97_DBL (1<<30) #define ICH_ALI_SC_AC97_DBL (1<<30)
...@@ -303,18 +304,40 @@ enum { ...@@ -303,18 +304,40 @@ enum {
* *
*/ */
enum { ICHD_PCMIN, ICHD_PCMOUT, ICHD_MIC, ICHD_MIC2, ICHD_PCM2IN, ICHD_SPBAR, ICHD_LAST = ICHD_SPBAR }; enum {
enum { NVD_PCMIN, NVD_PCMOUT, NVD_MIC, NVD_SPBAR, NVD_LAST = NVD_SPBAR }; ICHD_PCMIN,
enum { ALID_PCMIN, ALID_PCMOUT, ALID_MIC, ALID_AC97SPDIFOUT, ALID_SPDIFIN, ALID_SPDIFOUT, ALID_LAST = ALID_SPDIFOUT }; ICHD_PCMOUT,
ICHD_MIC,
ICHD_MIC2,
ICHD_PCM2IN,
ICHD_SPBAR,
ICHD_LAST = ICHD_SPBAR
};
enum {
NVD_PCMIN,
NVD_PCMOUT,
NVD_MIC,
NVD_SPBAR,
NVD_LAST = NVD_SPBAR
};
enum {
ALID_PCMIN,
ALID_PCMOUT,
ALID_MIC,
ALID_AC97SPDIFOUT,
ALID_SPDIFIN,
ALID_SPDIFOUT,
ALID_LAST = ALID_SPDIFOUT
};
#define get_ichdev(substream) (ichdev_t *)(substream->runtime->private_data) #define get_ichdev(substream) (substream->runtime->private_data)
typedef struct { struct ichdev {
unsigned int ichd; /* ich device number */ unsigned int ichd; /* ich device number */
unsigned long reg_offset; /* offset to bmaddr */ unsigned long reg_offset; /* offset to bmaddr */
u32 *bdbar; /* CPU address (32bit) */ u32 *bdbar; /* CPU address (32bit) */
unsigned int bdbar_addr; /* PCI bus address (32bit) */ unsigned int bdbar_addr; /* PCI bus address (32bit) */
snd_pcm_substream_t *substream; struct snd_pcm_substream *substream;
unsigned int physbuf; /* physical address (32bit) */ unsigned int physbuf; /* physical address (32bit) */
unsigned int size; unsigned int size;
unsigned int fragsize; unsigned int fragsize;
...@@ -336,11 +359,9 @@ typedef struct { ...@@ -336,11 +359,9 @@ typedef struct {
int pcm_open_flag; int pcm_open_flag;
unsigned int page_attr_changed: 1; unsigned int page_attr_changed: 1;
unsigned int suspended: 1; unsigned int suspended: 1;
} ichdev_t; };
typedef struct _snd_intel8x0 intel8x0_t;
struct _snd_intel8x0 { struct intel8x0 {
unsigned int device_type; unsigned int device_type;
int irq; int irq;
...@@ -353,11 +374,11 @@ struct _snd_intel8x0 { ...@@ -353,11 +374,11 @@ struct _snd_intel8x0 {
void __iomem *remap_bmaddr; void __iomem *remap_bmaddr;
struct pci_dev *pci; struct pci_dev *pci;
snd_card_t *card; struct snd_card *card;
int pcm_devs; int pcm_devs;
snd_pcm_t *pcm[6]; struct snd_pcm *pcm[6];
ichdev_t ichd[6]; struct ichdev ichd[6];
unsigned multi4: 1, unsigned multi4: 1,
multi6: 1, multi6: 1,
...@@ -374,8 +395,8 @@ struct _snd_intel8x0 { ...@@ -374,8 +395,8 @@ struct _snd_intel8x0 {
int spdif_idx; /* SPDIF BAR index; *_SPBAR or -1 if use PCMOUT */ int spdif_idx; /* SPDIF BAR index; *_SPBAR or -1 if use PCMOUT */
unsigned int sdm_saved; /* SDM reg value */ unsigned int sdm_saved; /* SDM reg value */
ac97_bus_t *ac97_bus; struct snd_ac97_bus *ac97_bus;
ac97_t *ac97[3]; struct snd_ac97 *ac97[3];
unsigned int ac97_sdin[3]; unsigned int ac97_sdin[3];
spinlock_t reg_lock; spinlock_t reg_lock;
...@@ -418,7 +439,7 @@ MODULE_DEVICE_TABLE(pci, snd_intel8x0_ids); ...@@ -418,7 +439,7 @@ MODULE_DEVICE_TABLE(pci, snd_intel8x0_ids);
* Lowlevel I/O - busmaster * Lowlevel I/O - busmaster
*/ */
static u8 igetbyte(intel8x0_t *chip, u32 offset) static u8 igetbyte(struct intel8x0 *chip, u32 offset)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
return readb(chip->remap_bmaddr + offset); return readb(chip->remap_bmaddr + offset);
...@@ -426,7 +447,7 @@ static u8 igetbyte(intel8x0_t *chip, u32 offset) ...@@ -426,7 +447,7 @@ static u8 igetbyte(intel8x0_t *chip, u32 offset)
return inb(chip->bmaddr + offset); return inb(chip->bmaddr + offset);
} }
static u16 igetword(intel8x0_t *chip, u32 offset) static u16 igetword(struct intel8x0 *chip, u32 offset)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
return readw(chip->remap_bmaddr + offset); return readw(chip->remap_bmaddr + offset);
...@@ -434,7 +455,7 @@ static u16 igetword(intel8x0_t *chip, u32 offset) ...@@ -434,7 +455,7 @@ static u16 igetword(intel8x0_t *chip, u32 offset)
return inw(chip->bmaddr + offset); return inw(chip->bmaddr + offset);
} }
static u32 igetdword(intel8x0_t *chip, u32 offset) static u32 igetdword(struct intel8x0 *chip, u32 offset)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
return readl(chip->remap_bmaddr + offset); return readl(chip->remap_bmaddr + offset);
...@@ -442,7 +463,7 @@ static u32 igetdword(intel8x0_t *chip, u32 offset) ...@@ -442,7 +463,7 @@ static u32 igetdword(intel8x0_t *chip, u32 offset)
return inl(chip->bmaddr + offset); return inl(chip->bmaddr + offset);
} }
static void iputbyte(intel8x0_t *chip, u32 offset, u8 val) static void iputbyte(struct intel8x0 *chip, u32 offset, u8 val)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
writeb(val, chip->remap_bmaddr + offset); writeb(val, chip->remap_bmaddr + offset);
...@@ -450,7 +471,7 @@ static void iputbyte(intel8x0_t *chip, u32 offset, u8 val) ...@@ -450,7 +471,7 @@ static void iputbyte(intel8x0_t *chip, u32 offset, u8 val)
outb(val, chip->bmaddr + offset); outb(val, chip->bmaddr + offset);
} }
static void iputword(intel8x0_t *chip, u32 offset, u16 val) static void iputword(struct intel8x0 *chip, u32 offset, u16 val)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
writew(val, chip->remap_bmaddr + offset); writew(val, chip->remap_bmaddr + offset);
...@@ -458,7 +479,7 @@ static void iputword(intel8x0_t *chip, u32 offset, u16 val) ...@@ -458,7 +479,7 @@ static void iputword(intel8x0_t *chip, u32 offset, u16 val)
outw(val, chip->bmaddr + offset); outw(val, chip->bmaddr + offset);
} }
static void iputdword(intel8x0_t *chip, u32 offset, u32 val) static void iputdword(struct intel8x0 *chip, u32 offset, u32 val)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
writel(val, chip->remap_bmaddr + offset); writel(val, chip->remap_bmaddr + offset);
...@@ -470,7 +491,7 @@ static void iputdword(intel8x0_t *chip, u32 offset, u32 val) ...@@ -470,7 +491,7 @@ static void iputdword(intel8x0_t *chip, u32 offset, u32 val)
* Lowlevel I/O - AC'97 registers * Lowlevel I/O - AC'97 registers
*/ */
static u16 iagetword(intel8x0_t *chip, u32 offset) static u16 iagetword(struct intel8x0 *chip, u32 offset)
{ {
if (chip->mmio) if (chip->mmio)
return readw(chip->remap_addr + offset); return readw(chip->remap_addr + offset);
...@@ -478,7 +499,7 @@ static u16 iagetword(intel8x0_t *chip, u32 offset) ...@@ -478,7 +499,7 @@ static u16 iagetword(intel8x0_t *chip, u32 offset)
return inw(chip->addr + offset); return inw(chip->addr + offset);
} }
static void iaputword(intel8x0_t *chip, u32 offset, u16 val) static void iaputword(struct intel8x0 *chip, u32 offset, u16 val)
{ {
if (chip->mmio) if (chip->mmio)
writew(val, chip->remap_addr + offset); writew(val, chip->remap_addr + offset);
...@@ -495,7 +516,7 @@ static void iaputword(intel8x0_t *chip, u32 offset, u16 val) ...@@ -495,7 +516,7 @@ static void iaputword(intel8x0_t *chip, u32 offset, u16 val)
*/ */
/* return the GLOB_STA bit for the corresponding codec */ /* return the GLOB_STA bit for the corresponding codec */
static unsigned int get_ich_codec_bit(intel8x0_t *chip, unsigned int codec) static unsigned int get_ich_codec_bit(struct intel8x0 *chip, unsigned int codec)
{ {
static unsigned int codec_bit[3] = { static unsigned int codec_bit[3] = {
ICH_PCR, ICH_SCR, ICH_TCR ICH_PCR, ICH_SCR, ICH_TCR
...@@ -506,7 +527,7 @@ static unsigned int get_ich_codec_bit(intel8x0_t *chip, unsigned int codec) ...@@ -506,7 +527,7 @@ static unsigned int get_ich_codec_bit(intel8x0_t *chip, unsigned int codec)
return codec_bit[codec]; return codec_bit[codec];
} }
static int snd_intel8x0_codec_semaphore(intel8x0_t *chip, unsigned int codec) static int snd_intel8x0_codec_semaphore(struct intel8x0 *chip, unsigned int codec)
{ {
int time; int time;
...@@ -545,11 +566,11 @@ static int snd_intel8x0_codec_semaphore(intel8x0_t *chip, unsigned int codec) ...@@ -545,11 +566,11 @@ static int snd_intel8x0_codec_semaphore(intel8x0_t *chip, unsigned int codec)
return -EBUSY; return -EBUSY;
} }
static void snd_intel8x0_codec_write(ac97_t *ac97, static void snd_intel8x0_codec_write(struct snd_ac97 *ac97,
unsigned short reg, unsigned short reg,
unsigned short val) unsigned short val)
{ {
intel8x0_t *chip = ac97->private_data; struct intel8x0 *chip = ac97->private_data;
if (snd_intel8x0_codec_semaphore(chip, ac97->num) < 0) { if (snd_intel8x0_codec_semaphore(chip, ac97->num) < 0) {
if (! chip->in_ac97_init) if (! chip->in_ac97_init)
...@@ -558,10 +579,10 @@ static void snd_intel8x0_codec_write(ac97_t *ac97, ...@@ -558,10 +579,10 @@ static void snd_intel8x0_codec_write(ac97_t *ac97,
iaputword(chip, reg + ac97->num * 0x80, val); iaputword(chip, reg + ac97->num * 0x80, val);
} }
static unsigned short snd_intel8x0_codec_read(ac97_t *ac97, static unsigned short snd_intel8x0_codec_read(struct snd_ac97 *ac97,
unsigned short reg) unsigned short reg)
{ {
intel8x0_t *chip = ac97->private_data; struct intel8x0 *chip = ac97->private_data;
unsigned short res; unsigned short res;
unsigned int tmp; unsigned int tmp;
...@@ -573,7 +594,8 @@ static unsigned short snd_intel8x0_codec_read(ac97_t *ac97, ...@@ -573,7 +594,8 @@ static unsigned short snd_intel8x0_codec_read(ac97_t *ac97,
res = iagetword(chip, reg + ac97->num * 0x80); res = iagetword(chip, reg + ac97->num * 0x80);
if ((tmp = igetdword(chip, ICHREG(GLOB_STA))) & ICH_RCS) { if ((tmp = igetdword(chip, ICHREG(GLOB_STA))) & ICH_RCS) {
/* reset RCS and preserve other R/WC bits */ /* reset RCS and preserve other R/WC bits */
iputdword(chip, ICHREG(GLOB_STA), tmp & ~(ICH_SRI|ICH_PRI|ICH_TRI|ICH_GSCI)); iputdword(chip, ICHREG(GLOB_STA), tmp &
~(ICH_SRI|ICH_PRI|ICH_TRI|ICH_GSCI));
if (! chip->in_ac97_init) if (! chip->in_ac97_init)
snd_printk(KERN_ERR "codec_read %d: read timeout for register 0x%x\n", ac97->num, reg); snd_printk(KERN_ERR "codec_read %d: read timeout for register 0x%x\n", ac97->num, reg);
res = 0xffff; res = 0xffff;
...@@ -582,7 +604,7 @@ static unsigned short snd_intel8x0_codec_read(ac97_t *ac97, ...@@ -582,7 +604,7 @@ static unsigned short snd_intel8x0_codec_read(ac97_t *ac97,
return res; return res;
} }
static void snd_intel8x0_codec_read_test(intel8x0_t *chip, unsigned int codec) static void snd_intel8x0_codec_read_test(struct intel8x0 *chip, unsigned int codec)
{ {
unsigned int tmp; unsigned int tmp;
...@@ -590,7 +612,8 @@ static void snd_intel8x0_codec_read_test(intel8x0_t *chip, unsigned int codec) ...@@ -590,7 +612,8 @@ static void snd_intel8x0_codec_read_test(intel8x0_t *chip, unsigned int codec)
iagetword(chip, codec * 0x80); iagetword(chip, codec * 0x80);
if ((tmp = igetdword(chip, ICHREG(GLOB_STA))) & ICH_RCS) { if ((tmp = igetdword(chip, ICHREG(GLOB_STA))) & ICH_RCS) {
/* reset RCS and preserve other R/WC bits */ /* reset RCS and preserve other R/WC bits */
iputdword(chip, ICHREG(GLOB_STA), tmp & ~(ICH_SRI|ICH_PRI|ICH_TRI|ICH_GSCI)); iputdword(chip, ICHREG(GLOB_STA), tmp &
~(ICH_SRI|ICH_PRI|ICH_TRI|ICH_GSCI));
} }
} }
} }
...@@ -598,7 +621,7 @@ static void snd_intel8x0_codec_read_test(intel8x0_t *chip, unsigned int codec) ...@@ -598,7 +621,7 @@ static void snd_intel8x0_codec_read_test(intel8x0_t *chip, unsigned int codec)
/* /*
* access to AC97 for Ali5455 * access to AC97 for Ali5455
*/ */
static int snd_intel8x0_ali_codec_ready(intel8x0_t *chip, int mask) static int snd_intel8x0_ali_codec_ready(struct intel8x0 *chip, int mask)
{ {
int count = 0; int count = 0;
for (count = 0; count < 0x7f; count++) { for (count = 0; count < 0x7f; count++) {
...@@ -611,7 +634,7 @@ static int snd_intel8x0_ali_codec_ready(intel8x0_t *chip, int mask) ...@@ -611,7 +634,7 @@ static int snd_intel8x0_ali_codec_ready(intel8x0_t *chip, int mask)
return -EBUSY; return -EBUSY;
} }
static int snd_intel8x0_ali_codec_semaphore(intel8x0_t *chip) static int snd_intel8x0_ali_codec_semaphore(struct intel8x0 *chip)
{ {
int time = 100; int time = 100;
if (chip->buggy_semaphore) if (chip->buggy_semaphore)
...@@ -623,9 +646,9 @@ static int snd_intel8x0_ali_codec_semaphore(intel8x0_t *chip) ...@@ -623,9 +646,9 @@ static int snd_intel8x0_ali_codec_semaphore(intel8x0_t *chip)
return snd_intel8x0_ali_codec_ready(chip, ALI_CSPSR_CODEC_READY); return snd_intel8x0_ali_codec_ready(chip, ALI_CSPSR_CODEC_READY);
} }
static unsigned short snd_intel8x0_ali_codec_read(ac97_t *ac97, unsigned short reg) static unsigned short snd_intel8x0_ali_codec_read(struct snd_ac97 *ac97, unsigned short reg)
{ {
intel8x0_t *chip = ac97->private_data; struct intel8x0 *chip = ac97->private_data;
unsigned short data = 0xffff; unsigned short data = 0xffff;
if (snd_intel8x0_ali_codec_semaphore(chip)) if (snd_intel8x0_ali_codec_semaphore(chip))
...@@ -641,9 +664,10 @@ static unsigned short snd_intel8x0_ali_codec_read(ac97_t *ac97, unsigned short r ...@@ -641,9 +664,10 @@ static unsigned short snd_intel8x0_ali_codec_read(ac97_t *ac97, unsigned short r
return data; return data;
} }
static void snd_intel8x0_ali_codec_write(ac97_t *ac97, unsigned short reg, unsigned short val) static void snd_intel8x0_ali_codec_write(struct snd_ac97 *ac97, unsigned short reg,
unsigned short val)
{ {
intel8x0_t *chip = ac97->private_data; struct intel8x0 *chip = ac97->private_data;
if (snd_intel8x0_ali_codec_semaphore(chip)) if (snd_intel8x0_ali_codec_semaphore(chip))
return; return;
...@@ -658,7 +682,7 @@ static void snd_intel8x0_ali_codec_write(ac97_t *ac97, unsigned short reg, unsig ...@@ -658,7 +682,7 @@ static void snd_intel8x0_ali_codec_write(ac97_t *ac97, unsigned short reg, unsig
/* /*
* DMA I/O * DMA I/O
*/ */
static void snd_intel8x0_setup_periods(intel8x0_t *chip, ichdev_t *ichdev) static void snd_intel8x0_setup_periods(struct intel8x0 *chip, struct ichdev *ichdev)
{ {
int idx; int idx;
u32 *bdbar = ichdev->bdbar; u32 *bdbar = ichdev->bdbar;
...@@ -681,10 +705,15 @@ static void snd_intel8x0_setup_periods(intel8x0_t *chip, ichdev_t *ichdev) ...@@ -681,10 +705,15 @@ static void snd_intel8x0_setup_periods(intel8x0_t *chip, ichdev_t *ichdev)
ichdev->ack_reload = ichdev->ack = 1; ichdev->ack_reload = ichdev->ack = 1;
ichdev->fragsize1 = ichdev->fragsize; ichdev->fragsize1 = ichdev->fragsize;
for (idx = 0; idx < (ICH_REG_LVI_MASK + 1) * 2; idx += 2) { for (idx = 0; idx < (ICH_REG_LVI_MASK + 1) * 2; idx += 2) {
bdbar[idx + 0] = cpu_to_le32(ichdev->physbuf + (((idx >> 1) * ichdev->fragsize) % ichdev->size)); bdbar[idx + 0] = cpu_to_le32(ichdev->physbuf +
(((idx >> 1) * ichdev->fragsize) %
ichdev->size));
bdbar[idx + 1] = cpu_to_le32(0x80000000 | /* interrupt on completion */ bdbar[idx + 1] = cpu_to_le32(0x80000000 | /* interrupt on completion */
ichdev->fragsize >> ichdev->pos_shift); ichdev->fragsize >> ichdev->pos_shift);
// printk("bdbar[%i] = 0x%x [0x%x]\n", idx + 0, bdbar[idx + 0], bdbar[idx + 1]); #if 0
printk("bdbar[%i] = 0x%x [0x%x]\n",
idx + 0, bdbar[idx + 0], bdbar[idx + 1]);
#endif
} }
ichdev->frags = ichdev->size / ichdev->fragsize; ichdev->frags = ichdev->size / ichdev->fragsize;
} }
...@@ -722,7 +751,7 @@ static void fill_nocache(void *buf, int size, int nocache) ...@@ -722,7 +751,7 @@ static void fill_nocache(void *buf, int size, int nocache)
* Interrupt handler * Interrupt handler
*/ */
static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev) static inline void snd_intel8x0_update(struct intel8x0 *chip, struct ichdev *ichdev)
{ {
unsigned long port = ichdev->reg_offset; unsigned long port = ichdev->reg_offset;
int status, civ, i, step; int status, civ, i, step;
...@@ -757,7 +786,12 @@ static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev) ...@@ -757,7 +786,12 @@ static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev)
ichdev->lvi_frag++; ichdev->lvi_frag++;
ichdev->lvi_frag %= ichdev->frags; ichdev->lvi_frag %= ichdev->frags;
ichdev->bdbar[ichdev->lvi * 2] = cpu_to_le32(ichdev->physbuf + ichdev->lvi_frag * ichdev->fragsize1); ichdev->bdbar[ichdev->lvi * 2] = cpu_to_le32(ichdev->physbuf + ichdev->lvi_frag * ichdev->fragsize1);
// printk("new: bdbar[%i] = 0x%x [0x%x], prefetch = %i, all = 0x%x, 0x%x\n", ichdev->lvi * 2, ichdev->bdbar[ichdev->lvi * 2], ichdev->bdbar[ichdev->lvi * 2 + 1], inb(ICH_REG_OFF_PIV + port), inl(port + 4), inb(port + ICH_REG_OFF_CR)); #if 0
printk("new: bdbar[%i] = 0x%x [0x%x], prefetch = %i, all = 0x%x, 0x%x\n",
ichdev->lvi * 2, ichdev->bdbar[ichdev->lvi * 2],
ichdev->bdbar[ichdev->lvi * 2 + 1], inb(ICH_REG_OFF_PIV + port),
inl(port + 4), inb(port + ICH_REG_OFF_CR));
#endif
if (--ichdev->ack == 0) { if (--ichdev->ack == 0) {
ichdev->ack = ichdev->ack_reload; ichdev->ack = ichdev->ack_reload;
ack = 1; ack = 1;
...@@ -773,8 +807,8 @@ static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev) ...@@ -773,8 +807,8 @@ static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev)
static irqreturn_t snd_intel8x0_interrupt(int irq, void *dev_id, struct pt_regs *regs) static irqreturn_t snd_intel8x0_interrupt(int irq, void *dev_id, struct pt_regs *regs)
{ {
intel8x0_t *chip = dev_id; struct intel8x0 *chip = dev_id;
ichdev_t *ichdev; struct ichdev *ichdev;
unsigned int status; unsigned int status;
unsigned int i; unsigned int i;
...@@ -808,10 +842,10 @@ static irqreturn_t snd_intel8x0_interrupt(int irq, void *dev_id, struct pt_regs ...@@ -808,10 +842,10 @@ static irqreturn_t snd_intel8x0_interrupt(int irq, void *dev_id, struct pt_regs
* PCM part * PCM part
*/ */
static int snd_intel8x0_pcm_trigger(snd_pcm_substream_t *substream, int cmd) static int snd_intel8x0_pcm_trigger(struct snd_pcm_substream *substream, int cmd)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
unsigned char val = 0; unsigned char val = 0;
unsigned long port = ichdev->reg_offset; unsigned long port = ichdev->reg_offset;
...@@ -847,12 +881,14 @@ static int snd_intel8x0_pcm_trigger(snd_pcm_substream_t *substream, int cmd) ...@@ -847,12 +881,14 @@ static int snd_intel8x0_pcm_trigger(snd_pcm_substream_t *substream, int cmd)
return 0; return 0;
} }
static int snd_intel8x0_ali_trigger(snd_pcm_substream_t *substream, int cmd) static int snd_intel8x0_ali_trigger(struct snd_pcm_substream *substream, int cmd)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
unsigned long port = ichdev->reg_offset; unsigned long port = ichdev->reg_offset;
static int fiforeg[] = { ICHREG(ALI_FIFOCR1), ICHREG(ALI_FIFOCR2), ICHREG(ALI_FIFOCR3) }; static int fiforeg[] = {
ICHREG(ALI_FIFOCR1), ICHREG(ALI_FIFOCR2), ICHREG(ALI_FIFOCR3)
};
unsigned int val, fifo; unsigned int val, fifo;
val = igetdword(chip, ICHREG(ALI_DMACR)); val = igetdword(chip, ICHREG(ALI_DMACR));
...@@ -871,14 +907,16 @@ static int snd_intel8x0_ali_trigger(snd_pcm_substream_t *substream, int cmd) ...@@ -871,14 +907,16 @@ static int snd_intel8x0_ali_trigger(snd_pcm_substream_t *substream, int cmd)
} }
iputbyte(chip, port + ICH_REG_OFF_CR, ICH_IOCE); iputbyte(chip, port + ICH_REG_OFF_CR, ICH_IOCE);
val &= ~(1 << (ichdev->ali_slot + 16)); /* clear PAUSE flag */ val &= ~(1 << (ichdev->ali_slot + 16)); /* clear PAUSE flag */
iputdword(chip, ICHREG(ALI_DMACR), val | (1 << ichdev->ali_slot)); /* start DMA */ /* start DMA */
iputdword(chip, ICHREG(ALI_DMACR), val | (1 << ichdev->ali_slot));
break; break;
case SNDRV_PCM_TRIGGER_SUSPEND: case SNDRV_PCM_TRIGGER_SUSPEND:
ichdev->suspended = 1; ichdev->suspended = 1;
/* fallthru */ /* fallthru */
case SNDRV_PCM_TRIGGER_STOP: case SNDRV_PCM_TRIGGER_STOP:
case SNDRV_PCM_TRIGGER_PAUSE_PUSH: case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
iputdword(chip, ICHREG(ALI_DMACR), val | (1 << (ichdev->ali_slot + 16))); /* pause */ /* pause */
iputdword(chip, ICHREG(ALI_DMACR), val | (1 << (ichdev->ali_slot + 16)));
iputbyte(chip, port + ICH_REG_OFF_CR, 0); iputbyte(chip, port + ICH_REG_OFF_CR, 0);
while (igetbyte(chip, port + ICH_REG_OFF_CR)) while (igetbyte(chip, port + ICH_REG_OFF_CR))
; ;
...@@ -887,7 +925,8 @@ static int snd_intel8x0_ali_trigger(snd_pcm_substream_t *substream, int cmd) ...@@ -887,7 +925,8 @@ static int snd_intel8x0_ali_trigger(snd_pcm_substream_t *substream, int cmd)
/* reset whole DMA things */ /* reset whole DMA things */
iputbyte(chip, port + ICH_REG_OFF_CR, ICH_RESETREGS); iputbyte(chip, port + ICH_REG_OFF_CR, ICH_RESETREGS);
/* clear interrupts */ /* clear interrupts */
iputbyte(chip, port + ICH_REG_OFF_SR, igetbyte(chip, port + ICH_REG_OFF_SR) | 0x1e); iputbyte(chip, port + ICH_REG_OFF_SR,
igetbyte(chip, port + ICH_REG_OFF_SR) | 0x1e);
iputdword(chip, ICHREG(ALI_INTERRUPTSR), iputdword(chip, ICHREG(ALI_INTERRUPTSR),
igetdword(chip, ICHREG(ALI_INTERRUPTSR)) & ichdev->int_sta_mask); igetdword(chip, ICHREG(ALI_INTERRUPTSR)) & ichdev->int_sta_mask);
break; break;
...@@ -897,12 +936,12 @@ static int snd_intel8x0_ali_trigger(snd_pcm_substream_t *substream, int cmd) ...@@ -897,12 +936,12 @@ static int snd_intel8x0_ali_trigger(snd_pcm_substream_t *substream, int cmd)
return 0; return 0;
} }
static int snd_intel8x0_hw_params(snd_pcm_substream_t * substream, static int snd_intel8x0_hw_params(struct snd_pcm_substream *substream,
snd_pcm_hw_params_t * hw_params) struct snd_pcm_hw_params *hw_params)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
snd_pcm_runtime_t *runtime = substream->runtime; struct snd_pcm_runtime *runtime = substream->runtime;
int dbl = params_rate(hw_params) > 48000; int dbl = params_rate(hw_params) > 48000;
int err; int err;
...@@ -930,15 +969,16 @@ static int snd_intel8x0_hw_params(snd_pcm_substream_t * substream, ...@@ -930,15 +969,16 @@ static int snd_intel8x0_hw_params(snd_pcm_substream_t * substream,
ichdev->pcm_open_flag = 1; ichdev->pcm_open_flag = 1;
/* Force SPDIF setting */ /* Force SPDIF setting */
if (ichdev->ichd == ICHD_PCMOUT && chip->spdif_idx < 0) if (ichdev->ichd == ICHD_PCMOUT && chip->spdif_idx < 0)
snd_ac97_set_rate(ichdev->pcm->r[0].codec[0], AC97_SPDIF, params_rate(hw_params)); snd_ac97_set_rate(ichdev->pcm->r[0].codec[0], AC97_SPDIF,
params_rate(hw_params));
} }
return err; return err;
} }
static int snd_intel8x0_hw_free(snd_pcm_substream_t * substream) static int snd_intel8x0_hw_free(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
if (ichdev->pcm_open_flag) { if (ichdev->pcm_open_flag) {
snd_ac97_pcm_close(ichdev->pcm); snd_ac97_pcm_close(ichdev->pcm);
...@@ -951,8 +991,8 @@ static int snd_intel8x0_hw_free(snd_pcm_substream_t * substream) ...@@ -951,8 +991,8 @@ static int snd_intel8x0_hw_free(snd_pcm_substream_t * substream)
return snd_pcm_lib_free_pages(substream); return snd_pcm_lib_free_pages(substream);
} }
static void snd_intel8x0_setup_pcm_out(intel8x0_t *chip, static void snd_intel8x0_setup_pcm_out(struct intel8x0 *chip,
snd_pcm_runtime_t *runtime) struct snd_pcm_runtime *runtime)
{ {
unsigned int cnt; unsigned int cnt;
int dbl = runtime->rate > 48000; int dbl = runtime->rate > 48000;
...@@ -1004,11 +1044,11 @@ static void snd_intel8x0_setup_pcm_out(intel8x0_t *chip, ...@@ -1004,11 +1044,11 @@ static void snd_intel8x0_setup_pcm_out(intel8x0_t *chip,
spin_unlock_irq(&chip->reg_lock); spin_unlock_irq(&chip->reg_lock);
} }
static int snd_intel8x0_pcm_prepare(snd_pcm_substream_t * substream) static int snd_intel8x0_pcm_prepare(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
snd_pcm_runtime_t *runtime = substream->runtime; struct snd_pcm_runtime *runtime = substream->runtime;
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
ichdev->physbuf = runtime->dma_addr; ichdev->physbuf = runtime->dma_addr;
ichdev->size = snd_pcm_lib_buffer_bytes(substream); ichdev->size = snd_pcm_lib_buffer_bytes(substream);
...@@ -1022,10 +1062,10 @@ static int snd_intel8x0_pcm_prepare(snd_pcm_substream_t * substream) ...@@ -1022,10 +1062,10 @@ static int snd_intel8x0_pcm_prepare(snd_pcm_substream_t * substream)
return 0; return 0;
} }
static snd_pcm_uframes_t snd_intel8x0_pcm_pointer(snd_pcm_substream_t * substream) static snd_pcm_uframes_t snd_intel8x0_pcm_pointer(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
size_t ptr1, ptr; size_t ptr1, ptr;
int civ, timeout = 100; int civ, timeout = 100;
unsigned int position; unsigned int position;
...@@ -1052,7 +1092,7 @@ static snd_pcm_uframes_t snd_intel8x0_pcm_pointer(snd_pcm_substream_t * substrea ...@@ -1052,7 +1092,7 @@ static snd_pcm_uframes_t snd_intel8x0_pcm_pointer(snd_pcm_substream_t * substrea
return bytes_to_frames(substream->runtime, ptr); return bytes_to_frames(substream->runtime, ptr);
} }
static snd_pcm_hardware_t snd_intel8x0_stream = static struct snd_pcm_hardware snd_intel8x0_stream =
{ {
.info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED |
SNDRV_PCM_INFO_BLOCK_TRANSFER | SNDRV_PCM_INFO_BLOCK_TRANSFER |
...@@ -1077,7 +1117,7 @@ static unsigned int channels4[] = { ...@@ -1077,7 +1117,7 @@ static unsigned int channels4[] = {
2, 4, 2, 4,
}; };
static snd_pcm_hw_constraint_list_t hw_constraints_channels4 = { static struct snd_pcm_hw_constraint_list hw_constraints_channels4 = {
.count = ARRAY_SIZE(channels4), .count = ARRAY_SIZE(channels4),
.list = channels4, .list = channels4,
.mask = 0, .mask = 0,
...@@ -1087,16 +1127,16 @@ static unsigned int channels6[] = { ...@@ -1087,16 +1127,16 @@ static unsigned int channels6[] = {
2, 4, 6, 2, 4, 6,
}; };
static snd_pcm_hw_constraint_list_t hw_constraints_channels6 = { static struct snd_pcm_hw_constraint_list hw_constraints_channels6 = {
.count = ARRAY_SIZE(channels6), .count = ARRAY_SIZE(channels6),
.list = channels6, .list = channels6,
.mask = 0, .mask = 0,
}; };
static int snd_intel8x0_pcm_open(snd_pcm_substream_t * substream, ichdev_t *ichdev) static int snd_intel8x0_pcm_open(struct snd_pcm_substream *substream, struct ichdev *ichdev)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
snd_pcm_runtime_t *runtime = substream->runtime; struct snd_pcm_runtime *runtime = substream->runtime;
int err; int err;
ichdev->substream = substream; ichdev->substream = substream;
...@@ -1113,10 +1153,10 @@ static int snd_intel8x0_pcm_open(snd_pcm_substream_t * substream, ichdev_t *ichd ...@@ -1113,10 +1153,10 @@ static int snd_intel8x0_pcm_open(snd_pcm_substream_t * substream, ichdev_t *ichd
return 0; return 0;
} }
static int snd_intel8x0_playback_open(snd_pcm_substream_t * substream) static int snd_intel8x0_playback_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
snd_pcm_runtime_t *runtime = substream->runtime; struct snd_pcm_runtime *runtime = substream->runtime;
int err; int err;
err = snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_PCMOUT]); err = snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_PCMOUT]);
...@@ -1125,10 +1165,12 @@ static int snd_intel8x0_playback_open(snd_pcm_substream_t * substream) ...@@ -1125,10 +1165,12 @@ static int snd_intel8x0_playback_open(snd_pcm_substream_t * substream)
if (chip->multi6) { if (chip->multi6) {
runtime->hw.channels_max = 6; runtime->hw.channels_max = 6;
snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS, &hw_constraints_channels6); snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS,
&hw_constraints_channels6);
} else if (chip->multi4) { } else if (chip->multi4) {
runtime->hw.channels_max = 4; runtime->hw.channels_max = 4;
snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS, &hw_constraints_channels4); snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_CHANNELS,
&hw_constraints_channels4);
} }
if (chip->dra) { if (chip->dra) {
snd_ac97_pcm_double_rate_rules(runtime); snd_ac97_pcm_double_rate_rules(runtime);
...@@ -1140,94 +1182,94 @@ static int snd_intel8x0_playback_open(snd_pcm_substream_t * substream) ...@@ -1140,94 +1182,94 @@ static int snd_intel8x0_playback_open(snd_pcm_substream_t * substream)
return 0; return 0;
} }
static int snd_intel8x0_playback_close(snd_pcm_substream_t * substream) static int snd_intel8x0_playback_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
chip->ichd[ICHD_PCMOUT].substream = NULL; chip->ichd[ICHD_PCMOUT].substream = NULL;
return 0; return 0;
} }
static int snd_intel8x0_capture_open(snd_pcm_substream_t * substream) static int snd_intel8x0_capture_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
return snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_PCMIN]); return snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_PCMIN]);
} }
static int snd_intel8x0_capture_close(snd_pcm_substream_t * substream) static int snd_intel8x0_capture_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
chip->ichd[ICHD_PCMIN].substream = NULL; chip->ichd[ICHD_PCMIN].substream = NULL;
return 0; return 0;
} }
static int snd_intel8x0_mic_open(snd_pcm_substream_t * substream) static int snd_intel8x0_mic_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
return snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_MIC]); return snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_MIC]);
} }
static int snd_intel8x0_mic_close(snd_pcm_substream_t * substream) static int snd_intel8x0_mic_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
chip->ichd[ICHD_MIC].substream = NULL; chip->ichd[ICHD_MIC].substream = NULL;
return 0; return 0;
} }
static int snd_intel8x0_mic2_open(snd_pcm_substream_t * substream) static int snd_intel8x0_mic2_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
return snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_MIC2]); return snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_MIC2]);
} }
static int snd_intel8x0_mic2_close(snd_pcm_substream_t * substream) static int snd_intel8x0_mic2_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
chip->ichd[ICHD_MIC2].substream = NULL; chip->ichd[ICHD_MIC2].substream = NULL;
return 0; return 0;
} }
static int snd_intel8x0_capture2_open(snd_pcm_substream_t * substream) static int snd_intel8x0_capture2_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
return snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_PCM2IN]); return snd_intel8x0_pcm_open(substream, &chip->ichd[ICHD_PCM2IN]);
} }
static int snd_intel8x0_capture2_close(snd_pcm_substream_t * substream) static int snd_intel8x0_capture2_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
chip->ichd[ICHD_PCM2IN].substream = NULL; chip->ichd[ICHD_PCM2IN].substream = NULL;
return 0; return 0;
} }
static int snd_intel8x0_spdif_open(snd_pcm_substream_t * substream) static int snd_intel8x0_spdif_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
int idx = chip->device_type == DEVICE_NFORCE ? NVD_SPBAR : ICHD_SPBAR; int idx = chip->device_type == DEVICE_NFORCE ? NVD_SPBAR : ICHD_SPBAR;
return snd_intel8x0_pcm_open(substream, &chip->ichd[idx]); return snd_intel8x0_pcm_open(substream, &chip->ichd[idx]);
} }
static int snd_intel8x0_spdif_close(snd_pcm_substream_t * substream) static int snd_intel8x0_spdif_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
int idx = chip->device_type == DEVICE_NFORCE ? NVD_SPBAR : ICHD_SPBAR; int idx = chip->device_type == DEVICE_NFORCE ? NVD_SPBAR : ICHD_SPBAR;
chip->ichd[idx].substream = NULL; chip->ichd[idx].substream = NULL;
return 0; return 0;
} }
static int snd_intel8x0_ali_ac97spdifout_open(snd_pcm_substream_t * substream) static int snd_intel8x0_ali_ac97spdifout_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
unsigned int val; unsigned int val;
spin_lock_irq(&chip->reg_lock); spin_lock_irq(&chip->reg_lock);
...@@ -1240,9 +1282,9 @@ static int snd_intel8x0_ali_ac97spdifout_open(snd_pcm_substream_t * substream) ...@@ -1240,9 +1282,9 @@ static int snd_intel8x0_ali_ac97spdifout_open(snd_pcm_substream_t * substream)
return snd_intel8x0_pcm_open(substream, &chip->ichd[ALID_AC97SPDIFOUT]); return snd_intel8x0_pcm_open(substream, &chip->ichd[ALID_AC97SPDIFOUT]);
} }
static int snd_intel8x0_ali_ac97spdifout_close(snd_pcm_substream_t * substream) static int snd_intel8x0_ali_ac97spdifout_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
unsigned int val; unsigned int val;
chip->ichd[ALID_AC97SPDIFOUT].substream = NULL; chip->ichd[ALID_AC97SPDIFOUT].substream = NULL;
...@@ -1255,39 +1297,39 @@ static int snd_intel8x0_ali_ac97spdifout_close(snd_pcm_substream_t * substream) ...@@ -1255,39 +1297,39 @@ static int snd_intel8x0_ali_ac97spdifout_close(snd_pcm_substream_t * substream)
return 0; return 0;
} }
static int snd_intel8x0_ali_spdifin_open(snd_pcm_substream_t * substream) static int snd_intel8x0_ali_spdifin_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
return snd_intel8x0_pcm_open(substream, &chip->ichd[ALID_SPDIFIN]); return snd_intel8x0_pcm_open(substream, &chip->ichd[ALID_SPDIFIN]);
} }
static int snd_intel8x0_ali_spdifin_close(snd_pcm_substream_t * substream) static int snd_intel8x0_ali_spdifin_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
chip->ichd[ALID_SPDIFIN].substream = NULL; chip->ichd[ALID_SPDIFIN].substream = NULL;
return 0; return 0;
} }
#if 0 // NYI #if 0 // NYI
static int snd_intel8x0_ali_spdifout_open(snd_pcm_substream_t * substream) static int snd_intel8x0_ali_spdifout_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
return snd_intel8x0_pcm_open(substream, &chip->ichd[ALID_SPDIFOUT]); return snd_intel8x0_pcm_open(substream, &chip->ichd[ALID_SPDIFOUT]);
} }
static int snd_intel8x0_ali_spdifout_close(snd_pcm_substream_t * substream) static int snd_intel8x0_ali_spdifout_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0 *chip = snd_pcm_substream_chip(substream);
chip->ichd[ALID_SPDIFOUT].substream = NULL; chip->ichd[ALID_SPDIFOUT].substream = NULL;
return 0; return 0;
} }
#endif #endif
static snd_pcm_ops_t snd_intel8x0_playback_ops = { static struct snd_pcm_ops snd_intel8x0_playback_ops = {
.open = snd_intel8x0_playback_open, .open = snd_intel8x0_playback_open,
.close = snd_intel8x0_playback_close, .close = snd_intel8x0_playback_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1298,7 +1340,7 @@ static snd_pcm_ops_t snd_intel8x0_playback_ops = { ...@@ -1298,7 +1340,7 @@ static snd_pcm_ops_t snd_intel8x0_playback_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_capture_ops = { static struct snd_pcm_ops snd_intel8x0_capture_ops = {
.open = snd_intel8x0_capture_open, .open = snd_intel8x0_capture_open,
.close = snd_intel8x0_capture_close, .close = snd_intel8x0_capture_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1309,7 +1351,7 @@ static snd_pcm_ops_t snd_intel8x0_capture_ops = { ...@@ -1309,7 +1351,7 @@ static snd_pcm_ops_t snd_intel8x0_capture_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_capture_mic_ops = { static struct snd_pcm_ops snd_intel8x0_capture_mic_ops = {
.open = snd_intel8x0_mic_open, .open = snd_intel8x0_mic_open,
.close = snd_intel8x0_mic_close, .close = snd_intel8x0_mic_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1320,7 +1362,7 @@ static snd_pcm_ops_t snd_intel8x0_capture_mic_ops = { ...@@ -1320,7 +1362,7 @@ static snd_pcm_ops_t snd_intel8x0_capture_mic_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_capture_mic2_ops = { static struct snd_pcm_ops snd_intel8x0_capture_mic2_ops = {
.open = snd_intel8x0_mic2_open, .open = snd_intel8x0_mic2_open,
.close = snd_intel8x0_mic2_close, .close = snd_intel8x0_mic2_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1331,7 +1373,7 @@ static snd_pcm_ops_t snd_intel8x0_capture_mic2_ops = { ...@@ -1331,7 +1373,7 @@ static snd_pcm_ops_t snd_intel8x0_capture_mic2_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_capture2_ops = { static struct snd_pcm_ops snd_intel8x0_capture2_ops = {
.open = snd_intel8x0_capture2_open, .open = snd_intel8x0_capture2_open,
.close = snd_intel8x0_capture2_close, .close = snd_intel8x0_capture2_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1342,7 +1384,7 @@ static snd_pcm_ops_t snd_intel8x0_capture2_ops = { ...@@ -1342,7 +1384,7 @@ static snd_pcm_ops_t snd_intel8x0_capture2_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_spdif_ops = { static struct snd_pcm_ops snd_intel8x0_spdif_ops = {
.open = snd_intel8x0_spdif_open, .open = snd_intel8x0_spdif_open,
.close = snd_intel8x0_spdif_close, .close = snd_intel8x0_spdif_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1353,7 +1395,7 @@ static snd_pcm_ops_t snd_intel8x0_spdif_ops = { ...@@ -1353,7 +1395,7 @@ static snd_pcm_ops_t snd_intel8x0_spdif_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_ali_playback_ops = { static struct snd_pcm_ops snd_intel8x0_ali_playback_ops = {
.open = snd_intel8x0_playback_open, .open = snd_intel8x0_playback_open,
.close = snd_intel8x0_playback_close, .close = snd_intel8x0_playback_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1364,7 +1406,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_playback_ops = { ...@@ -1364,7 +1406,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_playback_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_ali_capture_ops = { static struct snd_pcm_ops snd_intel8x0_ali_capture_ops = {
.open = snd_intel8x0_capture_open, .open = snd_intel8x0_capture_open,
.close = snd_intel8x0_capture_close, .close = snd_intel8x0_capture_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1375,7 +1417,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_capture_ops = { ...@@ -1375,7 +1417,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_capture_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_ali_capture_mic_ops = { static struct snd_pcm_ops snd_intel8x0_ali_capture_mic_ops = {
.open = snd_intel8x0_mic_open, .open = snd_intel8x0_mic_open,
.close = snd_intel8x0_mic_close, .close = snd_intel8x0_mic_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1386,7 +1428,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_capture_mic_ops = { ...@@ -1386,7 +1428,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_capture_mic_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_ali_ac97spdifout_ops = { static struct snd_pcm_ops snd_intel8x0_ali_ac97spdifout_ops = {
.open = snd_intel8x0_ali_ac97spdifout_open, .open = snd_intel8x0_ali_ac97spdifout_open,
.close = snd_intel8x0_ali_ac97spdifout_close, .close = snd_intel8x0_ali_ac97spdifout_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1397,7 +1439,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_ac97spdifout_ops = { ...@@ -1397,7 +1439,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_ac97spdifout_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0_ali_spdifin_ops = { static struct snd_pcm_ops snd_intel8x0_ali_spdifin_ops = {
.open = snd_intel8x0_ali_spdifin_open, .open = snd_intel8x0_ali_spdifin_open,
.close = snd_intel8x0_ali_spdifin_close, .close = snd_intel8x0_ali_spdifin_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1409,7 +1451,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_spdifin_ops = { ...@@ -1409,7 +1451,7 @@ static snd_pcm_ops_t snd_intel8x0_ali_spdifin_ops = {
}; };
#if 0 // NYI #if 0 // NYI
static snd_pcm_ops_t snd_intel8x0_ali_spdifout_ops = { static struct snd_pcm_ops snd_intel8x0_ali_spdifout_ops = {
.open = snd_intel8x0_ali_spdifout_open, .open = snd_intel8x0_ali_spdifout_open,
.close = snd_intel8x0_ali_spdifout_close, .close = snd_intel8x0_ali_spdifout_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -1423,16 +1465,17 @@ static snd_pcm_ops_t snd_intel8x0_ali_spdifout_ops = { ...@@ -1423,16 +1465,17 @@ static snd_pcm_ops_t snd_intel8x0_ali_spdifout_ops = {
struct ich_pcm_table { struct ich_pcm_table {
char *suffix; char *suffix;
snd_pcm_ops_t *playback_ops; struct snd_pcm_ops *playback_ops;
snd_pcm_ops_t *capture_ops; struct snd_pcm_ops *capture_ops;
size_t prealloc_size; size_t prealloc_size;
size_t prealloc_max_size; size_t prealloc_max_size;
int ac97_idx; int ac97_idx;
}; };
static int __devinit snd_intel8x0_pcm1(intel8x0_t *chip, int device, struct ich_pcm_table *rec) static int __devinit snd_intel8x0_pcm1(struct intel8x0 *chip, int device,
struct ich_pcm_table *rec)
{ {
snd_pcm_t *pcm; struct snd_pcm *pcm;
int err; int err;
char name[32]; char name[32];
...@@ -1459,7 +1502,8 @@ static int __devinit snd_intel8x0_pcm1(intel8x0_t *chip, int device, struct ich_ ...@@ -1459,7 +1502,8 @@ static int __devinit snd_intel8x0_pcm1(intel8x0_t *chip, int device, struct ich_
strcpy(pcm->name, chip->card->shortname); strcpy(pcm->name, chip->card->shortname);
chip->pcm[device] = pcm; chip->pcm[device] = pcm;
snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV, snd_dma_pci_data(chip->pci), snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV,
snd_dma_pci_data(chip->pci),
rec->prealloc_size, rec->prealloc_max_size); rec->prealloc_size, rec->prealloc_max_size);
return 0; return 0;
...@@ -1557,7 +1601,7 @@ static struct ich_pcm_table ali_pcms[] __devinitdata = { ...@@ -1557,7 +1601,7 @@ static struct ich_pcm_table ali_pcms[] __devinitdata = {
#endif #endif
}; };
static int __devinit snd_intel8x0_pcm(intel8x0_t *chip) static int __devinit snd_intel8x0_pcm(struct intel8x0 *chip)
{ {
int i, tblsize, device, err; int i, tblsize, device, err;
struct ich_pcm_table *tbl, *rec; struct ich_pcm_table *tbl, *rec;
...@@ -1604,15 +1648,15 @@ static int __devinit snd_intel8x0_pcm(intel8x0_t *chip) ...@@ -1604,15 +1648,15 @@ static int __devinit snd_intel8x0_pcm(intel8x0_t *chip)
* Mixer part * Mixer part
*/ */
static void snd_intel8x0_mixer_free_ac97_bus(ac97_bus_t *bus) static void snd_intel8x0_mixer_free_ac97_bus(struct snd_ac97_bus *bus)
{ {
intel8x0_t *chip = bus->private_data; struct intel8x0 *chip = bus->private_data;
chip->ac97_bus = NULL; chip->ac97_bus = NULL;
} }
static void snd_intel8x0_mixer_free_ac97(ac97_t *ac97) static void snd_intel8x0_mixer_free_ac97(struct snd_ac97 *ac97)
{ {
intel8x0_t *chip = ac97->private_data; struct intel8x0 *chip = ac97->private_data;
chip->ac97[ac97->num] = NULL; chip->ac97[ac97->num] = NULL;
} }
...@@ -1961,19 +2005,20 @@ static struct ac97_quirk ac97_quirks[] __devinitdata = { ...@@ -1961,19 +2005,20 @@ static struct ac97_quirk ac97_quirks[] __devinitdata = {
{ } /* terminator */ { } /* terminator */
}; };
static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock, const char *quirk_override) static int __devinit snd_intel8x0_mixer(struct intel8x0 *chip, int ac97_clock,
const char *quirk_override)
{ {
ac97_bus_t *pbus; struct snd_ac97_bus *pbus;
ac97_template_t ac97; struct snd_ac97_template ac97;
int err; int err;
unsigned int i, codecs; unsigned int i, codecs;
unsigned int glob_sta = 0; unsigned int glob_sta = 0;
ac97_bus_ops_t *ops; struct snd_ac97_bus_ops *ops;
static ac97_bus_ops_t standard_bus_ops = { static struct snd_ac97_bus_ops standard_bus_ops = {
.write = snd_intel8x0_codec_write, .write = snd_intel8x0_codec_write,
.read = snd_intel8x0_codec_read, .read = snd_intel8x0_codec_read,
}; };
static ac97_bus_ops_t ali_bus_ops = { static struct snd_ac97_bus_ops ali_bus_ops = {
.write = snd_intel8x0_ali_codec_write, .write = snd_intel8x0_ali_codec_write,
.read = snd_intel8x0_ali_codec_read, .read = snd_intel8x0_ali_codec_read,
}; };
...@@ -2128,7 +2173,8 @@ static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock, const ...@@ -2128,7 +2173,8 @@ static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock, const
__err: __err:
/* clear the cold-reset bit for the next chance */ /* clear the cold-reset bit for the next chance */
if (chip->device_type != DEVICE_ALI) if (chip->device_type != DEVICE_ALI)
iputdword(chip, ICHREG(GLOB_CNT), igetdword(chip, ICHREG(GLOB_CNT)) & ~ICH_AC97COLD); iputdword(chip, ICHREG(GLOB_CNT),
igetdword(chip, ICHREG(GLOB_CNT)) & ~ICH_AC97COLD);
return err; return err;
} }
...@@ -2137,7 +2183,7 @@ static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock, const ...@@ -2137,7 +2183,7 @@ static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock, const
* *
*/ */
static void do_ali_reset(intel8x0_t *chip) static void do_ali_reset(struct intel8x0 *chip)
{ {
iputdword(chip, ICHREG(ALI_SCR), ICH_ALI_SC_RESET); iputdword(chip, ICHREG(ALI_SCR), ICH_ALI_SC_RESET);
iputdword(chip, ICHREG(ALI_FIFOCR1), 0x83838383); iputdword(chip, ICHREG(ALI_FIFOCR1), 0x83838383);
...@@ -2149,7 +2195,7 @@ static void do_ali_reset(intel8x0_t *chip) ...@@ -2149,7 +2195,7 @@ static void do_ali_reset(intel8x0_t *chip)
iputdword(chip, ICHREG(ALI_INTERRUPTSR), 0x00000000); iputdword(chip, ICHREG(ALI_INTERRUPTSR), 0x00000000);
} }
static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing) static int snd_intel8x0_ich_chip_init(struct intel8x0 *chip, int probing)
{ {
unsigned long end_time; unsigned long end_time;
unsigned int cnt, status, nstatus; unsigned int cnt, status, nstatus;
...@@ -2174,7 +2220,8 @@ static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing) ...@@ -2174,7 +2220,8 @@ static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing)
goto __ok; goto __ok;
schedule_timeout_uninterruptible(1); schedule_timeout_uninterruptible(1);
} while (time_after_eq(end_time, jiffies)); } while (time_after_eq(end_time, jiffies));
snd_printk(KERN_ERR "AC'97 warm reset still in progress? [0x%x]\n", igetdword(chip, ICHREG(GLOB_CNT))); snd_printk(KERN_ERR "AC'97 warm reset still in progress? [0x%x]\n",
igetdword(chip, ICHREG(GLOB_CNT)));
return -EIO; return -EIO;
__ok: __ok:
...@@ -2185,14 +2232,16 @@ static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing) ...@@ -2185,14 +2232,16 @@ static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing)
*/ */
end_time = jiffies + HZ; end_time = jiffies + HZ;
do { do {
status = igetdword(chip, ICHREG(GLOB_STA)) & (ICH_PCR | ICH_SCR | ICH_TCR); status = igetdword(chip, ICHREG(GLOB_STA)) &
(ICH_PCR | ICH_SCR | ICH_TCR);
if (status) if (status)
break; break;
schedule_timeout_uninterruptible(1); schedule_timeout_uninterruptible(1);
} while (time_after_eq(end_time, jiffies)); } while (time_after_eq(end_time, jiffies));
if (! status) { if (! status) {
/* no codec is found */ /* no codec is found */
snd_printk(KERN_ERR "codec_ready: codec is not ready [0x%x]\n", igetdword(chip, ICHREG(GLOB_STA))); snd_printk(KERN_ERR "codec_ready: codec is not ready [0x%x]\n",
igetdword(chip, ICHREG(GLOB_STA)));
return -EIO; return -EIO;
} }
...@@ -2220,7 +2269,8 @@ static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing) ...@@ -2220,7 +2269,8 @@ static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing)
/* wait until all the probed codecs are ready */ /* wait until all the probed codecs are ready */
end_time = jiffies + HZ; end_time = jiffies + HZ;
do { do {
nstatus = igetdword(chip, ICHREG(GLOB_STA)) & (ICH_PCR | ICH_SCR | ICH_TCR); nstatus = igetdword(chip, ICHREG(GLOB_STA)) &
(ICH_PCR | ICH_SCR | ICH_TCR);
if (status == nstatus) if (status == nstatus)
break; break;
schedule_timeout_uninterruptible(1); schedule_timeout_uninterruptible(1);
...@@ -2241,7 +2291,7 @@ static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing) ...@@ -2241,7 +2291,7 @@ static int snd_intel8x0_ich_chip_init(intel8x0_t *chip, int probing)
return 0; return 0;
} }
static int snd_intel8x0_ali_chip_init(intel8x0_t *chip, int probing) static int snd_intel8x0_ali_chip_init(struct intel8x0 *chip, int probing)
{ {
u32 reg; u32 reg;
int i = 0; int i = 0;
...@@ -2276,7 +2326,7 @@ static int snd_intel8x0_ali_chip_init(intel8x0_t *chip, int probing) ...@@ -2276,7 +2326,7 @@ static int snd_intel8x0_ali_chip_init(intel8x0_t *chip, int probing)
return 0; return 0;
} }
static int snd_intel8x0_chip_init(intel8x0_t *chip, int probing) static int snd_intel8x0_chip_init(struct intel8x0 *chip, int probing)
{ {
unsigned int i; unsigned int i;
int err; int err;
...@@ -2298,11 +2348,12 @@ static int snd_intel8x0_chip_init(intel8x0_t *chip, int probing) ...@@ -2298,11 +2348,12 @@ static int snd_intel8x0_chip_init(intel8x0_t *chip, int probing)
iputbyte(chip, ICH_REG_OFF_CR + chip->ichd[i].reg_offset, ICH_RESETREGS); iputbyte(chip, ICH_REG_OFF_CR + chip->ichd[i].reg_offset, ICH_RESETREGS);
/* initialize Buffer Descriptor Lists */ /* initialize Buffer Descriptor Lists */
for (i = 0; i < chip->bdbars_count; i++) for (i = 0; i < chip->bdbars_count; i++)
iputdword(chip, ICH_REG_OFF_BDBAR + chip->ichd[i].reg_offset, chip->ichd[i].bdbar_addr); iputdword(chip, ICH_REG_OFF_BDBAR + chip->ichd[i].reg_offset,
chip->ichd[i].bdbar_addr);
return 0; return 0;
} }
static int snd_intel8x0_free(intel8x0_t *chip) static int snd_intel8x0_free(struct intel8x0 *chip)
{ {
unsigned int i; unsigned int i;
...@@ -2325,7 +2376,7 @@ static int snd_intel8x0_free(intel8x0_t *chip) ...@@ -2325,7 +2376,7 @@ static int snd_intel8x0_free(intel8x0_t *chip)
synchronize_irq(chip->irq); synchronize_irq(chip->irq);
__hw_end: __hw_end:
if (chip->irq >= 0) if (chip->irq >= 0)
free_irq(chip->irq, (void *)chip); free_irq(chip->irq, chip);
if (chip->bdbars.area) { if (chip->bdbars.area) {
if (chip->fix_nocache) if (chip->fix_nocache)
fill_nocache(chip->bdbars.area, chip->bdbars.bytes, 0); fill_nocache(chip->bdbars.area, chip->bdbars.bytes, 0);
...@@ -2345,9 +2396,9 @@ static int snd_intel8x0_free(intel8x0_t *chip) ...@@ -2345,9 +2396,9 @@ static int snd_intel8x0_free(intel8x0_t *chip)
/* /*
* power management * power management
*/ */
static int intel8x0_suspend(snd_card_t *card, pm_message_t state) static int intel8x0_suspend(struct snd_card *card, pm_message_t state)
{ {
intel8x0_t *chip = card->pm_private_data; struct intel8x0 *chip = card->pm_private_data;
int i; int i;
for (i = 0; i < chip->pcm_devs; i++) for (i = 0; i < chip->pcm_devs; i++)
...@@ -2355,9 +2406,9 @@ static int intel8x0_suspend(snd_card_t *card, pm_message_t state) ...@@ -2355,9 +2406,9 @@ static int intel8x0_suspend(snd_card_t *card, pm_message_t state)
/* clear nocache */ /* clear nocache */
if (chip->fix_nocache) { if (chip->fix_nocache) {
for (i = 0; i < chip->bdbars_count; i++) { for (i = 0; i < chip->bdbars_count; i++) {
ichdev_t *ichdev = &chip->ichd[i]; struct ichdev *ichdev = &chip->ichd[i];
if (ichdev->substream && ichdev->page_attr_changed) { if (ichdev->substream && ichdev->page_attr_changed) {
snd_pcm_runtime_t *runtime = ichdev->substream->runtime; struct snd_pcm_runtime *runtime = ichdev->substream->runtime;
if (runtime->dma_area) if (runtime->dma_area)
fill_nocache(runtime->dma_area, runtime->dma_bytes, 0); fill_nocache(runtime->dma_area, runtime->dma_bytes, 0);
} }
...@@ -2370,19 +2421,20 @@ static int intel8x0_suspend(snd_card_t *card, pm_message_t state) ...@@ -2370,19 +2421,20 @@ static int intel8x0_suspend(snd_card_t *card, pm_message_t state)
chip->sdm_saved = igetbyte(chip, ICHREG(SDM)); chip->sdm_saved = igetbyte(chip, ICHREG(SDM));
if (chip->irq >= 0) if (chip->irq >= 0)
free_irq(chip->irq, (void *)chip); free_irq(chip->irq, chip);
pci_disable_device(chip->pci); pci_disable_device(chip->pci);
return 0; return 0;
} }
static int intel8x0_resume(snd_card_t *card) static int intel8x0_resume(struct snd_card *card)
{ {
intel8x0_t *chip = card->pm_private_data; struct intel8x0 *chip = card->pm_private_data;
int i; int i;
pci_enable_device(chip->pci); pci_enable_device(chip->pci);
pci_set_master(chip->pci); pci_set_master(chip->pci);
request_irq(chip->irq, snd_intel8x0_interrupt, SA_INTERRUPT|SA_SHIRQ, card->shortname, (void *)chip); request_irq(chip->irq, snd_intel8x0_interrupt, SA_INTERRUPT|SA_SHIRQ,
card->shortname, chip);
synchronize_irq(chip->irq); synchronize_irq(chip->irq);
snd_intel8x0_chip_init(chip, 1); snd_intel8x0_chip_init(chip, 1);
...@@ -2407,9 +2459,9 @@ static int intel8x0_resume(snd_card_t *card) ...@@ -2407,9 +2459,9 @@ static int intel8x0_resume(snd_card_t *card)
/* refill nocache */ /* refill nocache */
if (chip->fix_nocache) { if (chip->fix_nocache) {
for (i = 0; i < chip->bdbars_count; i++) { for (i = 0; i < chip->bdbars_count; i++) {
ichdev_t *ichdev = &chip->ichd[i]; struct ichdev *ichdev = &chip->ichd[i];
if (ichdev->substream && ichdev->page_attr_changed) { if (ichdev->substream && ichdev->page_attr_changed) {
snd_pcm_runtime_t *runtime = ichdev->substream->runtime; struct snd_pcm_runtime *runtime = ichdev->substream->runtime;
if (runtime->dma_area) if (runtime->dma_area)
fill_nocache(runtime->dma_area, runtime->dma_bytes, 1); fill_nocache(runtime->dma_area, runtime->dma_bytes, 1);
} }
...@@ -2418,7 +2470,7 @@ static int intel8x0_resume(snd_card_t *card) ...@@ -2418,7 +2470,7 @@ static int intel8x0_resume(snd_card_t *card)
/* resume status */ /* resume status */
for (i = 0; i < chip->bdbars_count; i++) { for (i = 0; i < chip->bdbars_count; i++) {
ichdev_t *ichdev = &chip->ichd[i]; struct ichdev *ichdev = &chip->ichd[i];
unsigned long port = ichdev->reg_offset; unsigned long port = ichdev->reg_offset;
if (! ichdev->substream || ! ichdev->suspended) if (! ichdev->substream || ! ichdev->suspended)
continue; continue;
...@@ -2436,10 +2488,10 @@ static int intel8x0_resume(snd_card_t *card) ...@@ -2436,10 +2488,10 @@ static int intel8x0_resume(snd_card_t *card)
#define INTEL8X0_TESTBUF_SIZE 32768 /* enough large for one shot */ #define INTEL8X0_TESTBUF_SIZE 32768 /* enough large for one shot */
static void __devinit intel8x0_measure_ac97_clock(intel8x0_t *chip) static void __devinit intel8x0_measure_ac97_clock(struct intel8x0 *chip)
{ {
snd_pcm_substream_t *subs; struct snd_pcm_substream *subs;
ichdev_t *ichdev; struct ichdev *ichdev;
unsigned long port; unsigned long port;
unsigned long pos, t; unsigned long pos, t;
struct timeval start_time, stop_time; struct timeval start_time, stop_time;
...@@ -2516,10 +2568,10 @@ static void __devinit intel8x0_measure_ac97_clock(intel8x0_t *chip) ...@@ -2516,10 +2568,10 @@ static void __devinit intel8x0_measure_ac97_clock(intel8x0_t *chip)
printk(KERN_INFO "intel8x0: clocking to %d\n", chip->ac97_bus->clock); printk(KERN_INFO "intel8x0: clocking to %d\n", chip->ac97_bus->clock);
} }
static void snd_intel8x0_proc_read(snd_info_entry_t * entry, static void snd_intel8x0_proc_read(struct snd_info_entry * entry,
snd_info_buffer_t * buffer) struct snd_info_buffer *buffer)
{ {
intel8x0_t *chip = entry->private_data; struct intel8x0 *chip = entry->private_data;
unsigned int tmp; unsigned int tmp;
snd_iprintf(buffer, "Intel8x0\n\n"); snd_iprintf(buffer, "Intel8x0\n\n");
...@@ -2542,17 +2594,17 @@ static void snd_intel8x0_proc_read(snd_info_entry_t * entry, ...@@ -2542,17 +2594,17 @@ static void snd_intel8x0_proc_read(snd_info_entry_t * entry,
chip->ac97_sdin[2]); chip->ac97_sdin[2]);
} }
static void __devinit snd_intel8x0_proc_init(intel8x0_t * chip) static void __devinit snd_intel8x0_proc_init(struct intel8x0 * chip)
{ {
snd_info_entry_t *entry; struct snd_info_entry *entry;
if (! snd_card_proc_new(chip->card, "intel8x0", &entry)) if (! snd_card_proc_new(chip->card, "intel8x0", &entry))
snd_info_set_text_ops(entry, chip, 1024, snd_intel8x0_proc_read); snd_info_set_text_ops(entry, chip, 1024, snd_intel8x0_proc_read);
} }
static int snd_intel8x0_dev_free(snd_device_t *device) static int snd_intel8x0_dev_free(struct snd_device *device)
{ {
intel8x0_t *chip = device->device_data; struct intel8x0 *chip = device->device_data;
return snd_intel8x0_free(chip); return snd_intel8x0_free(chip);
} }
...@@ -2561,17 +2613,17 @@ struct ich_reg_info { ...@@ -2561,17 +2613,17 @@ struct ich_reg_info {
unsigned int offset; unsigned int offset;
}; };
static int __devinit snd_intel8x0_create(snd_card_t * card, static int __devinit snd_intel8x0_create(struct snd_card *card,
struct pci_dev *pci, struct pci_dev *pci,
unsigned long device_type, unsigned long device_type,
intel8x0_t ** r_intel8x0) struct intel8x0 ** r_intel8x0)
{ {
intel8x0_t *chip; struct intel8x0 *chip;
int err; int err;
unsigned int i; unsigned int i;
unsigned int int_sta_masks; unsigned int int_sta_masks;
ichdev_t *ichdev; struct ichdev *ichdev;
static snd_device_ops_t ops = { static struct snd_device_ops ops = {
.dev_free = snd_intel8x0_dev_free, .dev_free = snd_intel8x0_dev_free,
}; };
...@@ -2734,7 +2786,7 @@ static int __devinit snd_intel8x0_create(snd_card_t * card, ...@@ -2734,7 +2786,7 @@ static int __devinit snd_intel8x0_create(snd_card_t * card,
/* request irq after initializaing int_sta_mask, etc */ /* request irq after initializaing int_sta_mask, etc */
if (request_irq(pci->irq, snd_intel8x0_interrupt, if (request_irq(pci->irq, snd_intel8x0_interrupt,
SA_INTERRUPT|SA_SHIRQ, card->shortname, (void *)chip)) { SA_INTERRUPT|SA_SHIRQ, card->shortname, chip)) {
snd_printk(KERN_ERR "unable to grab IRQ %d\n", pci->irq); snd_printk(KERN_ERR "unable to grab IRQ %d\n", pci->irq);
snd_intel8x0_free(chip); snd_intel8x0_free(chip);
return -EBUSY; return -EBUSY;
...@@ -2793,8 +2845,8 @@ static struct shortname_table { ...@@ -2793,8 +2845,8 @@ static struct shortname_table {
static int __devinit snd_intel8x0_probe(struct pci_dev *pci, static int __devinit snd_intel8x0_probe(struct pci_dev *pci,
const struct pci_device_id *pci_id) const struct pci_device_id *pci_id)
{ {
snd_card_t *card; struct snd_card *card;
intel8x0_t *chip; struct intel8x0 *chip;
int err; int err;
struct shortname_table *name; struct shortname_table *name;
......
...@@ -38,7 +38,8 @@ ...@@ -38,7 +38,8 @@
#include <sound/initval.h> #include <sound/initval.h>
MODULE_AUTHOR("Jaroslav Kysela <perex@suse.cz>"); MODULE_AUTHOR("Jaroslav Kysela <perex@suse.cz>");
MODULE_DESCRIPTION("Intel 82801AA,82901AB,i810,i820,i830,i840,i845,MX440; SiS 7013; NVidia MCP/2/2S/3 modems"); MODULE_DESCRIPTION("Intel 82801AA,82901AB,i810,i820,i830,i840,i845,MX440; "
"SiS 7013; NVidia MCP/2/2S/3 modems");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
MODULE_SUPPORTED_DEVICE("{{Intel,82801AA-ICH}," MODULE_SUPPORTED_DEVICE("{{Intel,82801AA-ICH},"
"{Intel,82901AB-ICH0}," "{Intel,82901AB-ICH0},"
...@@ -163,14 +164,14 @@ DEFINE_REGSET(OFF, 0); /* offset */ ...@@ -163,14 +164,14 @@ DEFINE_REGSET(OFF, 0); /* offset */
enum { ICHD_MDMIN, ICHD_MDMOUT, ICHD_MDMLAST = ICHD_MDMOUT }; enum { ICHD_MDMIN, ICHD_MDMOUT, ICHD_MDMLAST = ICHD_MDMOUT };
enum { ALID_MDMIN, ALID_MDMOUT, ALID_MDMLAST = ALID_MDMOUT }; enum { ALID_MDMIN, ALID_MDMOUT, ALID_MDMLAST = ALID_MDMOUT };
#define get_ichdev(substream) (ichdev_t *)(substream->runtime->private_data) #define get_ichdev(substream) (substream->runtime->private_data)
typedef struct { struct ichdev {
unsigned int ichd; /* ich device number */ unsigned int ichd; /* ich device number */
unsigned long reg_offset; /* offset to bmaddr */ unsigned long reg_offset; /* offset to bmaddr */
u32 *bdbar; /* CPU address (32bit) */ u32 *bdbar; /* CPU address (32bit) */
unsigned int bdbar_addr; /* PCI bus address (32bit) */ unsigned int bdbar_addr; /* PCI bus address (32bit) */
snd_pcm_substream_t *substream; struct snd_pcm_substream *substream;
unsigned int physbuf; /* physical address (32bit) */ unsigned int physbuf; /* physical address (32bit) */
unsigned int size; unsigned int size;
unsigned int fragsize; unsigned int fragsize;
...@@ -187,12 +188,10 @@ typedef struct { ...@@ -187,12 +188,10 @@ typedef struct {
unsigned int roff_picb; unsigned int roff_picb;
unsigned int int_sta_mask; /* interrupt status mask */ unsigned int int_sta_mask; /* interrupt status mask */
unsigned int ali_slot; /* ALI DMA slot */ unsigned int ali_slot; /* ALI DMA slot */
ac97_t *ac97; struct snd_ac97 *ac97;
} ichdev_t; };
typedef struct _snd_intel8x0m intel8x0_t;
struct _snd_intel8x0m { struct intel8x0m {
unsigned int device_type; unsigned int device_type;
int irq; int irq;
...@@ -205,16 +204,16 @@ struct _snd_intel8x0m { ...@@ -205,16 +204,16 @@ struct _snd_intel8x0m {
void __iomem *remap_bmaddr; void __iomem *remap_bmaddr;
struct pci_dev *pci; struct pci_dev *pci;
snd_card_t *card; struct snd_card *card;
int pcm_devs; int pcm_devs;
snd_pcm_t *pcm[2]; struct snd_pcm *pcm[2];
ichdev_t ichd[2]; struct ichdev ichd[2];
unsigned int in_ac97_init: 1; unsigned int in_ac97_init: 1;
ac97_bus_t *ac97_bus; struct snd_ac97_bus *ac97_bus;
ac97_t *ac97; struct snd_ac97 *ac97;
spinlock_t reg_lock; spinlock_t reg_lock;
...@@ -254,7 +253,7 @@ MODULE_DEVICE_TABLE(pci, snd_intel8x0m_ids); ...@@ -254,7 +253,7 @@ MODULE_DEVICE_TABLE(pci, snd_intel8x0m_ids);
* Lowlevel I/O - busmaster * Lowlevel I/O - busmaster
*/ */
static u8 igetbyte(intel8x0_t *chip, u32 offset) static u8 igetbyte(struct intel8x0m *chip, u32 offset)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
return readb(chip->remap_bmaddr + offset); return readb(chip->remap_bmaddr + offset);
...@@ -262,7 +261,7 @@ static u8 igetbyte(intel8x0_t *chip, u32 offset) ...@@ -262,7 +261,7 @@ static u8 igetbyte(intel8x0_t *chip, u32 offset)
return inb(chip->bmaddr + offset); return inb(chip->bmaddr + offset);
} }
static u16 igetword(intel8x0_t *chip, u32 offset) static u16 igetword(struct intel8x0m *chip, u32 offset)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
return readw(chip->remap_bmaddr + offset); return readw(chip->remap_bmaddr + offset);
...@@ -270,7 +269,7 @@ static u16 igetword(intel8x0_t *chip, u32 offset) ...@@ -270,7 +269,7 @@ static u16 igetword(intel8x0_t *chip, u32 offset)
return inw(chip->bmaddr + offset); return inw(chip->bmaddr + offset);
} }
static u32 igetdword(intel8x0_t *chip, u32 offset) static u32 igetdword(struct intel8x0m *chip, u32 offset)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
return readl(chip->remap_bmaddr + offset); return readl(chip->remap_bmaddr + offset);
...@@ -278,7 +277,7 @@ static u32 igetdword(intel8x0_t *chip, u32 offset) ...@@ -278,7 +277,7 @@ static u32 igetdword(intel8x0_t *chip, u32 offset)
return inl(chip->bmaddr + offset); return inl(chip->bmaddr + offset);
} }
static void iputbyte(intel8x0_t *chip, u32 offset, u8 val) static void iputbyte(struct intel8x0m *chip, u32 offset, u8 val)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
writeb(val, chip->remap_bmaddr + offset); writeb(val, chip->remap_bmaddr + offset);
...@@ -286,7 +285,7 @@ static void iputbyte(intel8x0_t *chip, u32 offset, u8 val) ...@@ -286,7 +285,7 @@ static void iputbyte(intel8x0_t *chip, u32 offset, u8 val)
outb(val, chip->bmaddr + offset); outb(val, chip->bmaddr + offset);
} }
static void iputword(intel8x0_t *chip, u32 offset, u16 val) static void iputword(struct intel8x0m *chip, u32 offset, u16 val)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
writew(val, chip->remap_bmaddr + offset); writew(val, chip->remap_bmaddr + offset);
...@@ -294,7 +293,7 @@ static void iputword(intel8x0_t *chip, u32 offset, u16 val) ...@@ -294,7 +293,7 @@ static void iputword(intel8x0_t *chip, u32 offset, u16 val)
outw(val, chip->bmaddr + offset); outw(val, chip->bmaddr + offset);
} }
static void iputdword(intel8x0_t *chip, u32 offset, u32 val) static void iputdword(struct intel8x0m *chip, u32 offset, u32 val)
{ {
if (chip->bm_mmio) if (chip->bm_mmio)
writel(val, chip->remap_bmaddr + offset); writel(val, chip->remap_bmaddr + offset);
...@@ -306,7 +305,7 @@ static void iputdword(intel8x0_t *chip, u32 offset, u32 val) ...@@ -306,7 +305,7 @@ static void iputdword(intel8x0_t *chip, u32 offset, u32 val)
* Lowlevel I/O - AC'97 registers * Lowlevel I/O - AC'97 registers
*/ */
static u16 iagetword(intel8x0_t *chip, u32 offset) static u16 iagetword(struct intel8x0m *chip, u32 offset)
{ {
if (chip->mmio) if (chip->mmio)
return readw(chip->remap_addr + offset); return readw(chip->remap_addr + offset);
...@@ -314,7 +313,7 @@ static u16 iagetword(intel8x0_t *chip, u32 offset) ...@@ -314,7 +313,7 @@ static u16 iagetword(intel8x0_t *chip, u32 offset)
return inw(chip->addr + offset); return inw(chip->addr + offset);
} }
static void iaputword(intel8x0_t *chip, u32 offset, u16 val) static void iaputword(struct intel8x0m *chip, u32 offset, u16 val)
{ {
if (chip->mmio) if (chip->mmio)
writew(val, chip->remap_addr + offset); writew(val, chip->remap_addr + offset);
...@@ -331,7 +330,7 @@ static void iaputword(intel8x0_t *chip, u32 offset, u16 val) ...@@ -331,7 +330,7 @@ static void iaputword(intel8x0_t *chip, u32 offset, u16 val)
*/ */
/* return the GLOB_STA bit for the corresponding codec */ /* return the GLOB_STA bit for the corresponding codec */
static unsigned int get_ich_codec_bit(intel8x0_t *chip, unsigned int codec) static unsigned int get_ich_codec_bit(struct intel8x0m *chip, unsigned int codec)
{ {
static unsigned int codec_bit[3] = { static unsigned int codec_bit[3] = {
ICH_PCR, ICH_SCR, ICH_TCR ICH_PCR, ICH_SCR, ICH_TCR
...@@ -340,7 +339,7 @@ static unsigned int get_ich_codec_bit(intel8x0_t *chip, unsigned int codec) ...@@ -340,7 +339,7 @@ static unsigned int get_ich_codec_bit(intel8x0_t *chip, unsigned int codec)
return codec_bit[codec]; return codec_bit[codec];
} }
static int snd_intel8x0m_codec_semaphore(intel8x0_t *chip, unsigned int codec) static int snd_intel8x0m_codec_semaphore(struct intel8x0m *chip, unsigned int codec)
{ {
int time; int time;
...@@ -370,11 +369,11 @@ static int snd_intel8x0m_codec_semaphore(intel8x0_t *chip, unsigned int codec) ...@@ -370,11 +369,11 @@ static int snd_intel8x0m_codec_semaphore(intel8x0_t *chip, unsigned int codec)
return -EBUSY; return -EBUSY;
} }
static void snd_intel8x0_codec_write(ac97_t *ac97, static void snd_intel8x0_codec_write(struct snd_ac97 *ac97,
unsigned short reg, unsigned short reg,
unsigned short val) unsigned short val)
{ {
intel8x0_t *chip = ac97->private_data; struct intel8x0m *chip = ac97->private_data;
if (snd_intel8x0m_codec_semaphore(chip, ac97->num) < 0) { if (snd_intel8x0m_codec_semaphore(chip, ac97->num) < 0) {
if (! chip->in_ac97_init) if (! chip->in_ac97_init)
...@@ -383,10 +382,10 @@ static void snd_intel8x0_codec_write(ac97_t *ac97, ...@@ -383,10 +382,10 @@ static void snd_intel8x0_codec_write(ac97_t *ac97,
iaputword(chip, reg + ac97->num * 0x80, val); iaputword(chip, reg + ac97->num * 0x80, val);
} }
static unsigned short snd_intel8x0_codec_read(ac97_t *ac97, static unsigned short snd_intel8x0_codec_read(struct snd_ac97 *ac97,
unsigned short reg) unsigned short reg)
{ {
intel8x0_t *chip = ac97->private_data; struct intel8x0m *chip = ac97->private_data;
unsigned short res; unsigned short res;
unsigned int tmp; unsigned int tmp;
...@@ -398,7 +397,8 @@ static unsigned short snd_intel8x0_codec_read(ac97_t *ac97, ...@@ -398,7 +397,8 @@ static unsigned short snd_intel8x0_codec_read(ac97_t *ac97,
res = iagetword(chip, reg + ac97->num * 0x80); res = iagetword(chip, reg + ac97->num * 0x80);
if ((tmp = igetdword(chip, ICHREG(GLOB_STA))) & ICH_RCS) { if ((tmp = igetdword(chip, ICHREG(GLOB_STA))) & ICH_RCS) {
/* reset RCS and preserve other R/WC bits */ /* reset RCS and preserve other R/WC bits */
iputdword(chip, ICHREG(GLOB_STA), tmp & ~(ICH_SRI|ICH_PRI|ICH_TRI|ICH_GSCI)); iputdword(chip, ICHREG(GLOB_STA),
tmp & ~(ICH_SRI|ICH_PRI|ICH_TRI|ICH_GSCI));
if (! chip->in_ac97_init) if (! chip->in_ac97_init)
snd_printk(KERN_ERR "codec_read %d: read timeout for register 0x%x\n", ac97->num, reg); snd_printk(KERN_ERR "codec_read %d: read timeout for register 0x%x\n", ac97->num, reg);
res = 0xffff; res = 0xffff;
...@@ -413,7 +413,7 @@ static unsigned short snd_intel8x0_codec_read(ac97_t *ac97, ...@@ -413,7 +413,7 @@ static unsigned short snd_intel8x0_codec_read(ac97_t *ac97,
/* /*
* DMA I/O * DMA I/O
*/ */
static void snd_intel8x0_setup_periods(intel8x0_t *chip, ichdev_t *ichdev) static void snd_intel8x0_setup_periods(struct intel8x0m *chip, struct ichdev *ichdev)
{ {
int idx; int idx;
u32 *bdbar = ichdev->bdbar; u32 *bdbar = ichdev->bdbar;
...@@ -460,7 +460,7 @@ static void snd_intel8x0_setup_periods(intel8x0_t *chip, ichdev_t *ichdev) ...@@ -460,7 +460,7 @@ static void snd_intel8x0_setup_periods(intel8x0_t *chip, ichdev_t *ichdev)
* Interrupt handler * Interrupt handler
*/ */
static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev) static inline void snd_intel8x0_update(struct intel8x0m *chip, struct ichdev *ichdev)
{ {
unsigned long port = ichdev->reg_offset; unsigned long port = ichdev->reg_offset;
int civ, i, step; int civ, i, step;
...@@ -489,8 +489,15 @@ static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev) ...@@ -489,8 +489,15 @@ static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev)
for (i = 0; i < step; i++) { for (i = 0; i < step; i++) {
ichdev->lvi_frag++; ichdev->lvi_frag++;
ichdev->lvi_frag %= ichdev->frags; ichdev->lvi_frag %= ichdev->frags;
ichdev->bdbar[ichdev->lvi * 2] = cpu_to_le32(ichdev->physbuf + ichdev->lvi_frag * ichdev->fragsize1); ichdev->bdbar[ichdev->lvi * 2] = cpu_to_le32(ichdev->physbuf +
// printk("new: bdbar[%i] = 0x%x [0x%x], prefetch = %i, all = 0x%x, 0x%x\n", ichdev->lvi * 2, ichdev->bdbar[ichdev->lvi * 2], ichdev->bdbar[ichdev->lvi * 2 + 1], inb(ICH_REG_OFF_PIV + port), inl(port + 4), inb(port + ICH_REG_OFF_CR)); ichdev->lvi_frag *
ichdev->fragsize1);
#if 0
printk("new: bdbar[%i] = 0x%x [0x%x], prefetch = %i, all = 0x%x, 0x%x\n",
ichdev->lvi * 2, ichdev->bdbar[ichdev->lvi * 2],
ichdev->bdbar[ichdev->lvi * 2 + 1], inb(ICH_REG_OFF_PIV + port),
inl(port + 4), inb(port + ICH_REG_OFF_CR));
#endif
if (--ichdev->ack == 0) { if (--ichdev->ack == 0) {
ichdev->ack = ichdev->ack_reload; ichdev->ack = ichdev->ack_reload;
ack = 1; ack = 1;
...@@ -506,8 +513,8 @@ static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev) ...@@ -506,8 +513,8 @@ static inline void snd_intel8x0_update(intel8x0_t *chip, ichdev_t *ichdev)
static irqreturn_t snd_intel8x0_interrupt(int irq, void *dev_id, struct pt_regs *regs) static irqreturn_t snd_intel8x0_interrupt(int irq, void *dev_id, struct pt_regs *regs)
{ {
intel8x0_t *chip = dev_id; struct intel8x0m *chip = dev_id;
ichdev_t *ichdev; struct ichdev *ichdev;
unsigned int status; unsigned int status;
unsigned int i; unsigned int i;
...@@ -541,10 +548,10 @@ static irqreturn_t snd_intel8x0_interrupt(int irq, void *dev_id, struct pt_regs ...@@ -541,10 +548,10 @@ static irqreturn_t snd_intel8x0_interrupt(int irq, void *dev_id, struct pt_regs
* PCM part * PCM part
*/ */
static int snd_intel8x0_pcm_trigger(snd_pcm_substream_t *substream, int cmd) static int snd_intel8x0_pcm_trigger(struct snd_pcm_substream *substream, int cmd)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0m *chip = snd_pcm_substream_chip(substream);
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
unsigned char val = 0; unsigned char val = 0;
unsigned long port = ichdev->reg_offset; unsigned long port = ichdev->reg_offset;
...@@ -576,21 +583,21 @@ static int snd_intel8x0_pcm_trigger(snd_pcm_substream_t *substream, int cmd) ...@@ -576,21 +583,21 @@ static int snd_intel8x0_pcm_trigger(snd_pcm_substream_t *substream, int cmd)
return 0; return 0;
} }
static int snd_intel8x0_hw_params(snd_pcm_substream_t * substream, static int snd_intel8x0_hw_params(struct snd_pcm_substream *substream,
snd_pcm_hw_params_t * hw_params) struct snd_pcm_hw_params *hw_params)
{ {
return snd_pcm_lib_malloc_pages(substream, params_buffer_bytes(hw_params)); return snd_pcm_lib_malloc_pages(substream, params_buffer_bytes(hw_params));
} }
static int snd_intel8x0_hw_free(snd_pcm_substream_t * substream) static int snd_intel8x0_hw_free(struct snd_pcm_substream *substream)
{ {
return snd_pcm_lib_free_pages(substream); return snd_pcm_lib_free_pages(substream);
} }
static snd_pcm_uframes_t snd_intel8x0_pcm_pointer(snd_pcm_substream_t * substream) static snd_pcm_uframes_t snd_intel8x0_pcm_pointer(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0m *chip = snd_pcm_substream_chip(substream);
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
size_t ptr1, ptr; size_t ptr1, ptr;
ptr1 = igetword(chip, ichdev->reg_offset + ichdev->roff_picb) << chip->pcm_pos_shift; ptr1 = igetword(chip, ichdev->reg_offset + ichdev->roff_picb) << chip->pcm_pos_shift;
...@@ -604,11 +611,11 @@ static snd_pcm_uframes_t snd_intel8x0_pcm_pointer(snd_pcm_substream_t * substrea ...@@ -604,11 +611,11 @@ static snd_pcm_uframes_t snd_intel8x0_pcm_pointer(snd_pcm_substream_t * substrea
return bytes_to_frames(substream->runtime, ptr); return bytes_to_frames(substream->runtime, ptr);
} }
static int snd_intel8x0m_pcm_prepare(snd_pcm_substream_t * substream) static int snd_intel8x0m_pcm_prepare(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0m *chip = snd_pcm_substream_chip(substream);
snd_pcm_runtime_t *runtime = substream->runtime; struct snd_pcm_runtime *runtime = substream->runtime;
ichdev_t *ichdev = get_ichdev(substream); struct ichdev *ichdev = get_ichdev(substream);
ichdev->physbuf = runtime->dma_addr; ichdev->physbuf = runtime->dma_addr;
ichdev->size = snd_pcm_lib_buffer_bytes(substream); ichdev->size = snd_pcm_lib_buffer_bytes(substream);
...@@ -619,7 +626,7 @@ static int snd_intel8x0m_pcm_prepare(snd_pcm_substream_t * substream) ...@@ -619,7 +626,7 @@ static int snd_intel8x0m_pcm_prepare(snd_pcm_substream_t * substream)
return 0; return 0;
} }
static snd_pcm_hardware_t snd_intel8x0m_stream = static struct snd_pcm_hardware snd_intel8x0m_stream =
{ {
.info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED |
SNDRV_PCM_INFO_BLOCK_TRANSFER | SNDRV_PCM_INFO_BLOCK_TRANSFER |
...@@ -641,58 +648,59 @@ static snd_pcm_hardware_t snd_intel8x0m_stream = ...@@ -641,58 +648,59 @@ static snd_pcm_hardware_t snd_intel8x0m_stream =
}; };
static int snd_intel8x0m_pcm_open(snd_pcm_substream_t * substream, ichdev_t *ichdev) static int snd_intel8x0m_pcm_open(struct snd_pcm_substream *substream, struct ichdev *ichdev)
{ {
static unsigned int rates[] = { 8000, 9600, 12000, 16000 }; static unsigned int rates[] = { 8000, 9600, 12000, 16000 };
static snd_pcm_hw_constraint_list_t hw_constraints_rates = { static struct snd_pcm_hw_constraint_list hw_constraints_rates = {
.count = ARRAY_SIZE(rates), .count = ARRAY_SIZE(rates),
.list = rates, .list = rates,
.mask = 0, .mask = 0,
}; };
snd_pcm_runtime_t *runtime = substream->runtime; struct snd_pcm_runtime *runtime = substream->runtime;
int err; int err;
ichdev->substream = substream; ichdev->substream = substream;
runtime->hw = snd_intel8x0m_stream; runtime->hw = snd_intel8x0m_stream;
err = snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_RATE, &hw_constraints_rates); err = snd_pcm_hw_constraint_list(runtime, 0, SNDRV_PCM_HW_PARAM_RATE,
&hw_constraints_rates);
if ( err < 0 ) if ( err < 0 )
return err; return err;
runtime->private_data = ichdev; runtime->private_data = ichdev;
return 0; return 0;
} }
static int snd_intel8x0m_playback_open(snd_pcm_substream_t * substream) static int snd_intel8x0m_playback_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0m *chip = snd_pcm_substream_chip(substream);
return snd_intel8x0m_pcm_open(substream, &chip->ichd[ICHD_MDMOUT]); return snd_intel8x0m_pcm_open(substream, &chip->ichd[ICHD_MDMOUT]);
} }
static int snd_intel8x0m_playback_close(snd_pcm_substream_t * substream) static int snd_intel8x0m_playback_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0m *chip = snd_pcm_substream_chip(substream);
chip->ichd[ICHD_MDMOUT].substream = NULL; chip->ichd[ICHD_MDMOUT].substream = NULL;
return 0; return 0;
} }
static int snd_intel8x0m_capture_open(snd_pcm_substream_t * substream) static int snd_intel8x0m_capture_open(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0m *chip = snd_pcm_substream_chip(substream);
return snd_intel8x0m_pcm_open(substream, &chip->ichd[ICHD_MDMIN]); return snd_intel8x0m_pcm_open(substream, &chip->ichd[ICHD_MDMIN]);
} }
static int snd_intel8x0m_capture_close(snd_pcm_substream_t * substream) static int snd_intel8x0m_capture_close(struct snd_pcm_substream *substream)
{ {
intel8x0_t *chip = snd_pcm_substream_chip(substream); struct intel8x0m *chip = snd_pcm_substream_chip(substream);
chip->ichd[ICHD_MDMIN].substream = NULL; chip->ichd[ICHD_MDMIN].substream = NULL;
return 0; return 0;
} }
static snd_pcm_ops_t snd_intel8x0m_playback_ops = { static struct snd_pcm_ops snd_intel8x0m_playback_ops = {
.open = snd_intel8x0m_playback_open, .open = snd_intel8x0m_playback_open,
.close = snd_intel8x0m_playback_close, .close = snd_intel8x0m_playback_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -703,7 +711,7 @@ static snd_pcm_ops_t snd_intel8x0m_playback_ops = { ...@@ -703,7 +711,7 @@ static snd_pcm_ops_t snd_intel8x0m_playback_ops = {
.pointer = snd_intel8x0_pcm_pointer, .pointer = snd_intel8x0_pcm_pointer,
}; };
static snd_pcm_ops_t snd_intel8x0m_capture_ops = { static struct snd_pcm_ops snd_intel8x0m_capture_ops = {
.open = snd_intel8x0m_capture_open, .open = snd_intel8x0m_capture_open,
.close = snd_intel8x0m_capture_close, .close = snd_intel8x0m_capture_close,
.ioctl = snd_pcm_lib_ioctl, .ioctl = snd_pcm_lib_ioctl,
...@@ -717,16 +725,17 @@ static snd_pcm_ops_t snd_intel8x0m_capture_ops = { ...@@ -717,16 +725,17 @@ static snd_pcm_ops_t snd_intel8x0m_capture_ops = {
struct ich_pcm_table { struct ich_pcm_table {
char *suffix; char *suffix;
snd_pcm_ops_t *playback_ops; struct snd_pcm_ops *playback_ops;
snd_pcm_ops_t *capture_ops; struct snd_pcm_ops *capture_ops;
size_t prealloc_size; size_t prealloc_size;
size_t prealloc_max_size; size_t prealloc_max_size;
int ac97_idx; int ac97_idx;
}; };
static int __devinit snd_intel8x0_pcm1(intel8x0_t *chip, int device, struct ich_pcm_table *rec) static int __devinit snd_intel8x0_pcm1(struct intel8x0m *chip, int device,
struct ich_pcm_table *rec)
{ {
snd_pcm_t *pcm; struct snd_pcm *pcm;
int err; int err;
char name[32]; char name[32];
...@@ -772,7 +781,7 @@ static struct ich_pcm_table intel_pcms[] __devinitdata = { ...@@ -772,7 +781,7 @@ static struct ich_pcm_table intel_pcms[] __devinitdata = {
}, },
}; };
static int __devinit snd_intel8x0_pcm(intel8x0_t *chip) static int __devinit snd_intel8x0_pcm(struct intel8x0m *chip)
{ {
int i, tblsize, device, err; int i, tblsize, device, err;
struct ich_pcm_table *tbl, *rec; struct ich_pcm_table *tbl, *rec;
...@@ -819,27 +828,27 @@ static int __devinit snd_intel8x0_pcm(intel8x0_t *chip) ...@@ -819,27 +828,27 @@ static int __devinit snd_intel8x0_pcm(intel8x0_t *chip)
* Mixer part * Mixer part
*/ */
static void snd_intel8x0_mixer_free_ac97_bus(ac97_bus_t *bus) static void snd_intel8x0_mixer_free_ac97_bus(struct snd_ac97_bus *bus)
{ {
intel8x0_t *chip = bus->private_data; struct intel8x0m *chip = bus->private_data;
chip->ac97_bus = NULL; chip->ac97_bus = NULL;
} }
static void snd_intel8x0_mixer_free_ac97(ac97_t *ac97) static void snd_intel8x0_mixer_free_ac97(struct snd_ac97 *ac97)
{ {
intel8x0_t *chip = ac97->private_data; struct intel8x0m *chip = ac97->private_data;
chip->ac97 = NULL; chip->ac97 = NULL;
} }
static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock) static int __devinit snd_intel8x0_mixer(struct intel8x0m *chip, int ac97_clock)
{ {
ac97_bus_t *pbus; struct snd_ac97_bus *pbus;
ac97_template_t ac97; struct snd_ac97_template ac97;
ac97_t *x97; struct snd_ac97 *x97;
int err; int err;
unsigned int glob_sta = 0; unsigned int glob_sta = 0;
static ac97_bus_ops_t ops = { static struct snd_ac97_bus_ops ops = {
.write = snd_intel8x0_codec_write, .write = snd_intel8x0_codec_write,
.read = snd_intel8x0_codec_read, .read = snd_intel8x0_codec_read,
}; };
...@@ -880,7 +889,8 @@ static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock) ...@@ -880,7 +889,8 @@ static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock)
__err: __err:
/* clear the cold-reset bit for the next chance */ /* clear the cold-reset bit for the next chance */
if (chip->device_type != DEVICE_ALI) if (chip->device_type != DEVICE_ALI)
iputdword(chip, ICHREG(GLOB_CNT), igetdword(chip, ICHREG(GLOB_CNT)) & ~ICH_AC97COLD); iputdword(chip, ICHREG(GLOB_CNT),
igetdword(chip, ICHREG(GLOB_CNT)) & ~ICH_AC97COLD);
return err; return err;
} }
...@@ -889,7 +899,7 @@ static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock) ...@@ -889,7 +899,7 @@ static int __devinit snd_intel8x0_mixer(intel8x0_t *chip, int ac97_clock)
* *
*/ */
static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing) static int snd_intel8x0m_ich_chip_init(struct intel8x0m *chip, int probing)
{ {
unsigned long end_time; unsigned long end_time;
unsigned int cnt, status, nstatus; unsigned int cnt, status, nstatus;
...@@ -912,7 +922,8 @@ static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing) ...@@ -912,7 +922,8 @@ static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing)
goto __ok; goto __ok;
schedule_timeout_uninterruptible(1); schedule_timeout_uninterruptible(1);
} while (time_after_eq(end_time, jiffies)); } while (time_after_eq(end_time, jiffies));
snd_printk(KERN_ERR "AC'97 warm reset still in progress? [0x%x]\n", igetdword(chip, ICHREG(GLOB_CNT))); snd_printk(KERN_ERR "AC'97 warm reset still in progress? [0x%x]\n",
igetdword(chip, ICHREG(GLOB_CNT)));
return -EIO; return -EIO;
__ok: __ok:
...@@ -923,14 +934,16 @@ static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing) ...@@ -923,14 +934,16 @@ static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing)
*/ */
end_time = jiffies + HZ; end_time = jiffies + HZ;
do { do {
status = igetdword(chip, ICHREG(GLOB_STA)) & (ICH_PCR | ICH_SCR | ICH_TCR); status = igetdword(chip, ICHREG(GLOB_STA)) &
(ICH_PCR | ICH_SCR | ICH_TCR);
if (status) if (status)
break; break;
schedule_timeout_uninterruptible(1); schedule_timeout_uninterruptible(1);
} while (time_after_eq(end_time, jiffies)); } while (time_after_eq(end_time, jiffies));
if (! status) { if (! status) {
/* no codec is found */ /* no codec is found */
snd_printk(KERN_ERR "codec_ready: codec is not ready [0x%x]\n", igetdword(chip, ICHREG(GLOB_STA))); snd_printk(KERN_ERR "codec_ready: codec is not ready [0x%x]\n",
igetdword(chip, ICHREG(GLOB_STA)));
return -EIO; return -EIO;
} }
...@@ -952,7 +965,8 @@ static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing) ...@@ -952,7 +965,8 @@ static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing)
/* wait until all the probed codecs are ready */ /* wait until all the probed codecs are ready */
end_time = jiffies + HZ; end_time = jiffies + HZ;
do { do {
nstatus = igetdword(chip, ICHREG(GLOB_STA)) & (ICH_PCR | ICH_SCR | ICH_TCR); nstatus = igetdword(chip, ICHREG(GLOB_STA)) &
(ICH_PCR | ICH_SCR | ICH_TCR);
if (status == nstatus) if (status == nstatus)
break; break;
schedule_timeout_uninterruptible(1); schedule_timeout_uninterruptible(1);
...@@ -967,7 +981,7 @@ static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing) ...@@ -967,7 +981,7 @@ static int snd_intel8x0m_ich_chip_init(intel8x0_t *chip, int probing)
return 0; return 0;
} }
static int snd_intel8x0_chip_init(intel8x0_t *chip, int probing) static int snd_intel8x0_chip_init(struct intel8x0m *chip, int probing)
{ {
unsigned int i; unsigned int i;
int err; int err;
...@@ -988,7 +1002,7 @@ static int snd_intel8x0_chip_init(intel8x0_t *chip, int probing) ...@@ -988,7 +1002,7 @@ static int snd_intel8x0_chip_init(intel8x0_t *chip, int probing)
return 0; return 0;
} }
static int snd_intel8x0_free(intel8x0_t *chip) static int snd_intel8x0_free(struct intel8x0m *chip)
{ {
unsigned int i; unsigned int i;
...@@ -1010,7 +1024,7 @@ static int snd_intel8x0_free(intel8x0_t *chip) ...@@ -1010,7 +1024,7 @@ static int snd_intel8x0_free(intel8x0_t *chip)
if (chip->remap_bmaddr) if (chip->remap_bmaddr)
iounmap(chip->remap_bmaddr); iounmap(chip->remap_bmaddr);
if (chip->irq >= 0) if (chip->irq >= 0)
free_irq(chip->irq, (void *)chip); free_irq(chip->irq, chip);
pci_release_regions(chip->pci); pci_release_regions(chip->pci);
pci_disable_device(chip->pci); pci_disable_device(chip->pci);
kfree(chip); kfree(chip);
...@@ -1021,9 +1035,9 @@ static int snd_intel8x0_free(intel8x0_t *chip) ...@@ -1021,9 +1035,9 @@ static int snd_intel8x0_free(intel8x0_t *chip)
/* /*
* power management * power management
*/ */
static int intel8x0m_suspend(snd_card_t *card, pm_message_t state) static int intel8x0m_suspend(struct snd_card *card, pm_message_t state)
{ {
intel8x0_t *chip = card->pm_private_data; struct intel8x0m *chip = card->pm_private_data;
int i; int i;
for (i = 0; i < chip->pcm_devs; i++) for (i = 0; i < chip->pcm_devs; i++)
...@@ -1034,9 +1048,9 @@ static int intel8x0m_suspend(snd_card_t *card, pm_message_t state) ...@@ -1034,9 +1048,9 @@ static int intel8x0m_suspend(snd_card_t *card, pm_message_t state)
return 0; return 0;
} }
static int intel8x0m_resume(snd_card_t *card) static int intel8x0m_resume(struct snd_card *card)
{ {
intel8x0_t *chip = card->pm_private_data; struct intel8x0m *chip = card->pm_private_data;
pci_enable_device(chip->pci); pci_enable_device(chip->pci);
pci_set_master(chip->pci); pci_set_master(chip->pci);
snd_intel8x0_chip_init(chip, 0); snd_intel8x0_chip_init(chip, 0);
...@@ -1047,17 +1061,18 @@ static int intel8x0m_resume(snd_card_t *card) ...@@ -1047,17 +1061,18 @@ static int intel8x0m_resume(snd_card_t *card)
} }
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
static void snd_intel8x0m_proc_read(snd_info_entry_t * entry, static void snd_intel8x0m_proc_read(struct snd_info_entry * entry,
snd_info_buffer_t * buffer) struct snd_info_buffer *buffer)
{ {
intel8x0_t *chip = entry->private_data; struct intel8x0m *chip = entry->private_data;
unsigned int tmp; unsigned int tmp;
snd_iprintf(buffer, "Intel8x0m\n\n"); snd_iprintf(buffer, "Intel8x0m\n\n");
if (chip->device_type == DEVICE_ALI) if (chip->device_type == DEVICE_ALI)
return; return;
tmp = igetdword(chip, ICHREG(GLOB_STA)); tmp = igetdword(chip, ICHREG(GLOB_STA));
snd_iprintf(buffer, "Global control : 0x%08x\n", igetdword(chip, ICHREG(GLOB_CNT))); snd_iprintf(buffer, "Global control : 0x%08x\n",
igetdword(chip, ICHREG(GLOB_CNT)));
snd_iprintf(buffer, "Global status : 0x%08x\n", tmp); snd_iprintf(buffer, "Global status : 0x%08x\n", tmp);
snd_iprintf(buffer, "AC'97 codecs ready :%s%s%s%s\n", snd_iprintf(buffer, "AC'97 codecs ready :%s%s%s%s\n",
tmp & ICH_PCR ? " primary" : "", tmp & ICH_PCR ? " primary" : "",
...@@ -1066,17 +1081,17 @@ static void snd_intel8x0m_proc_read(snd_info_entry_t * entry, ...@@ -1066,17 +1081,17 @@ static void snd_intel8x0m_proc_read(snd_info_entry_t * entry,
(tmp & (ICH_PCR | ICH_SCR | ICH_TCR)) == 0 ? " none" : ""); (tmp & (ICH_PCR | ICH_SCR | ICH_TCR)) == 0 ? " none" : "");
} }
static void __devinit snd_intel8x0m_proc_init(intel8x0_t * chip) static void __devinit snd_intel8x0m_proc_init(struct intel8x0m * chip)
{ {
snd_info_entry_t *entry; struct snd_info_entry *entry;
if (! snd_card_proc_new(chip->card, "intel8x0m", &entry)) if (! snd_card_proc_new(chip->card, "intel8x0m", &entry))
snd_info_set_text_ops(entry, chip, 1024, snd_intel8x0m_proc_read); snd_info_set_text_ops(entry, chip, 1024, snd_intel8x0m_proc_read);
} }
static int snd_intel8x0_dev_free(snd_device_t *device) static int snd_intel8x0_dev_free(struct snd_device *device)
{ {
intel8x0_t *chip = device->device_data; struct intel8x0m *chip = device->device_data;
return snd_intel8x0_free(chip); return snd_intel8x0_free(chip);
} }
...@@ -1085,17 +1100,17 @@ struct ich_reg_info { ...@@ -1085,17 +1100,17 @@ struct ich_reg_info {
unsigned int offset; unsigned int offset;
}; };
static int __devinit snd_intel8x0m_create(snd_card_t * card, static int __devinit snd_intel8x0m_create(struct snd_card *card,
struct pci_dev *pci, struct pci_dev *pci,
unsigned long device_type, unsigned long device_type,
intel8x0_t ** r_intel8x0) struct intel8x0m ** r_intel8x0)
{ {
intel8x0_t *chip; struct intel8x0m *chip;
int err; int err;
unsigned int i; unsigned int i;
unsigned int int_sta_masks; unsigned int int_sta_masks;
ichdev_t *ichdev; struct ichdev *ichdev;
static snd_device_ops_t ops = { static struct snd_device_ops ops = {
.dev_free = snd_intel8x0_dev_free, .dev_free = snd_intel8x0_dev_free,
}; };
static struct ich_reg_info intel_regs[2] = { static struct ich_reg_info intel_regs[2] = {
...@@ -1160,7 +1175,8 @@ static int __devinit snd_intel8x0m_create(snd_card_t * card, ...@@ -1160,7 +1175,8 @@ static int __devinit snd_intel8x0m_create(snd_card_t * card,
} }
port_inited: port_inited:
if (request_irq(pci->irq, snd_intel8x0_interrupt, SA_INTERRUPT|SA_SHIRQ, card->shortname, (void *)chip)) { if (request_irq(pci->irq, snd_intel8x0_interrupt, SA_INTERRUPT|SA_SHIRQ,
card->shortname, chip)) {
snd_printk(KERN_ERR "unable to grab IRQ %d\n", pci->irq); snd_printk(KERN_ERR "unable to grab IRQ %d\n", pci->irq);
snd_intel8x0_free(chip); snd_intel8x0_free(chip);
return -EBUSY; return -EBUSY;
...@@ -1259,8 +1275,8 @@ static struct shortname_table { ...@@ -1259,8 +1275,8 @@ static struct shortname_table {
static int __devinit snd_intel8x0m_probe(struct pci_dev *pci, static int __devinit snd_intel8x0m_probe(struct pci_dev *pci,
const struct pci_device_id *pci_id) const struct pci_device_id *pci_id)
{ {
snd_card_t *card; struct snd_card *card;
intel8x0_t *chip; struct intel8x0m *chip;
int err; int err;
struct shortname_table *name; struct shortname_table *name;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment