Commit da41dfb2 authored by Alan Cox's avatar Alan Cox Committed by Linus Torvalds

[PATCH] remove ifs from ancient backcompat in mwave driver

Also add warning about a broken spinlock/sleep someone still has to fix
parent ca6cc6fa
...@@ -53,46 +53,20 @@ ...@@ -53,46 +53,20 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/major.h> #include <linux/major.h>
#include <linux/miscdevice.h> #include <linux/miscdevice.h>
#include <linux/proc_fs.h> #include <linux/device.h>
#include <linux/serial.h> #include <linux/serial.h>
#include <linux/sched.h> #include <linux/sched.h>
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0)
#include <linux/spinlock.h> #include <linux/spinlock.h>
#else
#include <asm/spinlock.h>
#endif
#include <linux/delay.h> #include <linux/delay.h>
#include "smapi.h" #include "smapi.h"
#include "mwavedd.h" #include "mwavedd.h"
#include "3780i.h" #include "3780i.h"
#include "tp3780i.h" #include "tp3780i.h"
#ifndef __exit
#define __exit
#endif
MODULE_DESCRIPTION("3780i Advanced Communications Processor (Mwave) driver"); MODULE_DESCRIPTION("3780i Advanced Communications Processor (Mwave) driver");
MODULE_AUTHOR("Mike Sullivan and Paul Schroeder"); MODULE_AUTHOR("Mike Sullivan and Paul Schroeder");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0)
static int mwave_get_info(char *buf, char **start, off_t offset, int len);
#else
static int mwave_read_proc(char *buf, char **start, off_t offset, int xlen, int unused);
static struct proc_dir_entry mwave_proc = {
0, /* unsigned short low_ino */
5, /* unsigned short namelen */
"mwave", /* const char *name */
S_IFREG | S_IRUGO, /* mode_t mode */
1, /* nlink_t nlink */
0, /* uid_t uid */
0, /* gid_t gid */
0, /* unsigned long size */
NULL, /* struct inode_operations *ops */
&mwave_read_proc /* int (*get_info) (...) */
};
#endif
/* /*
* These parameters support the setting of MWave resources. Note that no * These parameters support the setting of MWave resources. Note that no
* checks are made against other devices (ie. superio) for conflicts. * checks are made against other devices (ie. superio) for conflicts.
...@@ -157,19 +131,23 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -157,19 +131,23 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
case IOCTL_MW_RESET: case IOCTL_MW_RESET:
PRINTK_1(TRACE_MWAVE, PRINTK_1(TRACE_MWAVE,
"mwavedd::mwave_ioctl, IOCTL_MW_RESET calling tp3780I_ResetDSP\n"); "mwavedd::mwave_ioctl, IOCTL_MW_RESET"
" calling tp3780I_ResetDSP\n");
retval = tp3780I_ResetDSP(&pDrvData->rBDData); retval = tp3780I_ResetDSP(&pDrvData->rBDData);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl, IOCTL_MW_RESET retval %x from tp3780I_ResetDSP\n", "mwavedd::mwave_ioctl, IOCTL_MW_RESET"
" retval %x from tp3780I_ResetDSP\n",
retval); retval);
break; break;
case IOCTL_MW_RUN: case IOCTL_MW_RUN:
PRINTK_1(TRACE_MWAVE, PRINTK_1(TRACE_MWAVE,
"mwavedd::mwave_ioctl, IOCTL_MW_RUN calling tp3780I_StartDSP\n"); "mwavedd::mwave_ioctl, IOCTL_MW_RUN"
" calling tp3780I_StartDSP\n");
retval = tp3780I_StartDSP(&pDrvData->rBDData); retval = tp3780I_StartDSP(&pDrvData->rBDData);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl, IOCTL_MW_RUN retval %x from tp3780I_StartDSP\n", "mwavedd::mwave_ioctl, IOCTL_MW_RUN"
" retval %x from tp3780I_StartDSP\n",
retval); retval);
break; break;
...@@ -177,17 +155,24 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -177,17 +155,24 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
MW_ABILITIES rAbilities; MW_ABILITIES rAbilities;
PRINTK_1(TRACE_MWAVE, PRINTK_1(TRACE_MWAVE,
"mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES calling tp3780I_QueryAbilities\n"); "mwavedd::mwave_ioctl,"
retval = tp3780I_QueryAbilities(&pDrvData->rBDData, &rAbilities); " IOCTL_MW_DSP_ABILITIES calling"
" tp3780I_QueryAbilities\n");
retval = tp3780I_QueryAbilities(&pDrvData->rBDData,
&rAbilities);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES retval %x from tp3780I_QueryAbilities\n", "mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES"
" retval %x from tp3780I_QueryAbilities\n",
retval); retval);
if (retval == 0) { if (retval == 0) {
if( copy_to_user((char *) ioarg, (char *) &rAbilities, sizeof(MW_ABILITIES)) ) if( copy_to_user((char *) ioarg,
(char *) &rAbilities,
sizeof(MW_ABILITIES)) )
return -EFAULT; return -EFAULT;
} }
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES exit retval %x\n", "mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES"
" exit retval %x\n",
retval); retval);
} }
break; break;
...@@ -197,15 +182,21 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -197,15 +182,21 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
MW_READWRITE rReadData; MW_READWRITE rReadData;
unsigned short *pusBuffer = 0; unsigned short *pusBuffer = 0;
if( copy_from_user((char *) &rReadData, (char *) ioarg, sizeof(MW_READWRITE)) ) if( copy_from_user((char *) &rReadData,
(char *) ioarg,
sizeof(MW_READWRITE)) )
return -EFAULT; return -EFAULT;
pusBuffer = (unsigned short *) (rReadData.pBuf); pusBuffer = (unsigned short *) (rReadData.pBuf);
PRINTK_4(TRACE_MWAVE, PRINTK_4(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_READ_DATA, size %lx, ioarg %lx pusBuffer %p\n", "mwavedd::mwave_ioctl IOCTL_MW_READ_DATA,"
" size %lx, ioarg %lx pusBuffer %p\n",
rReadData.ulDataLength, ioarg, pusBuffer); rReadData.ulDataLength, ioarg, pusBuffer);
retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData, iocmd, retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData,
(void *) pusBuffer, rReadData.ulDataLength, rReadData.usDspAddress); iocmd,
(void *) pusBuffer,
rReadData.ulDataLength,
rReadData.usDspAddress);
} }
break; break;
...@@ -213,12 +204,14 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -213,12 +204,14 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
MW_READWRITE rReadData; MW_READWRITE rReadData;
unsigned short *pusBuffer = 0; unsigned short *pusBuffer = 0;
if( copy_from_user((char *) &rReadData, (char *) ioarg, sizeof(MW_READWRITE)) ) if( copy_from_user((char *) &rReadData, (char *) ioarg,
sizeof(MW_READWRITE)) )
return -EFAULT; return -EFAULT;
pusBuffer = (unsigned short *) (rReadData.pBuf); pusBuffer = (unsigned short *) (rReadData.pBuf);
PRINTK_4(TRACE_MWAVE, PRINTK_4(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_READ_INST, size %lx, ioarg %lx pusBuffer %p\n", "mwavedd::mwave_ioctl IOCTL_MW_READ_INST,"
" size %lx, ioarg %lx pusBuffer %p\n",
rReadData.ulDataLength / 2, ioarg, rReadData.ulDataLength / 2, ioarg,
pusBuffer); pusBuffer);
retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData, retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData,
...@@ -232,16 +225,21 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -232,16 +225,21 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
MW_READWRITE rWriteData; MW_READWRITE rWriteData;
unsigned short *pusBuffer = 0; unsigned short *pusBuffer = 0;
if( copy_from_user((char *) &rWriteData, (char *) ioarg, sizeof(MW_READWRITE)) ) if( copy_from_user((char *) &rWriteData,
(char *) ioarg,
sizeof(MW_READWRITE)) )
return -EFAULT; return -EFAULT;
pusBuffer = (unsigned short *) (rWriteData.pBuf); pusBuffer = (unsigned short *) (rWriteData.pBuf);
PRINTK_4(TRACE_MWAVE, PRINTK_4(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_WRITE_DATA, size %lx, ioarg %lx pusBuffer %p\n", "mwavedd::mwave_ioctl IOCTL_MW_WRITE_DATA,"
" size %lx, ioarg %lx pusBuffer %p\n",
rWriteData.ulDataLength, ioarg, rWriteData.ulDataLength, ioarg,
pusBuffer); pusBuffer);
retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData, iocmd, retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData,
pusBuffer, rWriteData.ulDataLength, rWriteData.usDspAddress); iocmd, pusBuffer,
rWriteData.ulDataLength,
rWriteData.usDspAddress);
} }
break; break;
...@@ -249,16 +247,21 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -249,16 +247,21 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
MW_READWRITE rWriteData; MW_READWRITE rWriteData;
unsigned short *pusBuffer = 0; unsigned short *pusBuffer = 0;
if( copy_from_user((char *) &rWriteData, (char *) ioarg, sizeof(MW_READWRITE)) ) if( copy_from_user((char *) &rWriteData,
(char *) ioarg,
sizeof(MW_READWRITE)) )
return -EFAULT; return -EFAULT;
pusBuffer = (unsigned short *) (rWriteData.pBuf); pusBuffer = (unsigned short *) (rWriteData.pBuf);
PRINTK_4(TRACE_MWAVE, PRINTK_4(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_WRITE_INST, size %lx, ioarg %lx pusBuffer %p\n", "mwavedd::mwave_ioctl IOCTL_MW_WRITE_INST,"
" size %lx, ioarg %lx pusBuffer %p\n",
rWriteData.ulDataLength, ioarg, rWriteData.ulDataLength, ioarg,
pusBuffer); pusBuffer);
retval = tp3780I_ReadWriteDspIStore(&pDrvData->rBDData, iocmd, retval = tp3780I_ReadWriteDspIStore(&pDrvData->rBDData,
pusBuffer, rWriteData.ulDataLength, rWriteData.usDspAddress); iocmd, pusBuffer,
rWriteData.ulDataLength,
rWriteData.usDspAddress);
} }
break; break;
...@@ -266,23 +269,25 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -266,23 +269,25 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
unsigned int ipcnum = (unsigned int) ioarg; unsigned int ipcnum = (unsigned int) ioarg;
PRINTK_3(TRACE_MWAVE, PRINTK_3(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC ipcnum %x entry usIntCount %x\n", "mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC"
" ipcnum %x entry usIntCount %x\n",
ipcnum, ipcnum,
pDrvData->IPCs[ipcnum].usIntCount); pDrvData->IPCs[ipcnum].usIntCount);
if (ipcnum > 16) { if (ipcnum > ARRAY_SIZE(pDrvData->IPCs)) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::mwave_ioctl: IOCTL_MW_REGISTER_IPC: Error: Invalid ipcnum %x\n", ipcnum); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd::mwave_ioctl:"
" IOCTL_MW_REGISTER_IPC:"
" Error: Invalid ipcnum %x\n",
ipcnum);
return -EINVAL; return -EINVAL;
} }
pDrvData->IPCs[ipcnum].bIsHere = FALSE; pDrvData->IPCs[ipcnum].bIsHere = FALSE;
pDrvData->IPCs[ipcnum].bIsEnabled = TRUE; pDrvData->IPCs[ipcnum].bIsEnabled = TRUE;
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0)
#else
current->priority = 0x28; /* boost to provide priority timing */
#endif
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC ipcnum %x exit\n", "mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC"
" ipcnum %x exit\n",
ipcnum); ipcnum);
} }
break; break;
...@@ -293,17 +298,22 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -293,17 +298,22 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
unsigned long flags; unsigned long flags;
PRINTK_3(TRACE_MWAVE, PRINTK_3(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_GET_IPC ipcnum %x, usIntCount %x\n", "mwavedd::mwave_ioctl IOCTL_MW_GET_IPC"
" ipcnum %x, usIntCount %x\n",
ipcnum, ipcnum,
pDrvData->IPCs[ipcnum].usIntCount); pDrvData->IPCs[ipcnum].usIntCount);
if (ipcnum > 16) { if (ipcnum > ARRAY_SIZE(pDrvData->IPCs)) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::mwave_ioctl: IOCTL_MW_GET_IPC: Error: Invalid ipcnum %x\n", ipcnum); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd::mwave_ioctl:"
" IOCTL_MW_GET_IPC: Error:"
" Invalid ipcnum %x\n", ipcnum);
return -EINVAL; return -EINVAL;
} }
if (pDrvData->IPCs[ipcnum].bIsEnabled == TRUE) { if (pDrvData->IPCs[ipcnum].bIsEnabled == TRUE) {
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl, thread for ipc %x going to sleep\n", "mwavedd::mwave_ioctl, thread for"
" ipc %x going to sleep\n",
ipcnum); ipcnum);
spin_lock_irqsave(&ipc_lock, flags); spin_lock_irqsave(&ipc_lock, flags);
...@@ -313,10 +323,13 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -313,10 +323,13 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
pDrvData->IPCs[ipcnum].usIntCount = 2; /* first int has been handled */ pDrvData->IPCs[ipcnum].usIntCount = 2; /* first int has been handled */
spin_unlock_irqrestore(&ipc_lock, flags); spin_unlock_irqrestore(&ipc_lock, flags);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_GET_IPC ipcnum %x handling first int\n", "mwavedd::mwave_ioctl"
" IOCTL_MW_GET_IPC ipcnum %x"
" handling first int\n",
ipcnum); ipcnum);
} else { /* either 1st int has not yet occurred, or we have already handled the first int */ } else { /* either 1st int has not yet occurred, or we have already handled the first int */
pDrvData->IPCs[ipcnum].bIsHere = TRUE; pDrvData->IPCs[ipcnum].bIsHere = TRUE;
#warning "Sleeping on spinlock"
interruptible_sleep_on(&pDrvData->IPCs[ipcnum].ipc_wait_queue); interruptible_sleep_on(&pDrvData->IPCs[ipcnum].ipc_wait_queue);
pDrvData->IPCs[ipcnum].bIsHere = FALSE; pDrvData->IPCs[ipcnum].bIsHere = FALSE;
if (pDrvData->IPCs[ipcnum].usIntCount == 1) { if (pDrvData->IPCs[ipcnum].usIntCount == 1) {
...@@ -325,11 +338,16 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -325,11 +338,16 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
} }
spin_unlock_irqrestore(&ipc_lock, flags); spin_unlock_irqrestore(&ipc_lock, flags);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_GET_IPC ipcnum %x woke up and returning to application\n", "mwavedd::mwave_ioctl"
" IOCTL_MW_GET_IPC ipcnum %x"
" woke up and returning to"
" application\n",
ipcnum); ipcnum);
} }
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_GET_IPC, returning thread for ipc %x processing\n", "mwavedd::mwave_ioctl IOCTL_MW_GET_IPC,"
" returning thread for ipc %x"
" processing\n",
ipcnum); ipcnum);
} }
} }
...@@ -339,10 +357,15 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -339,10 +357,15 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
unsigned int ipcnum = (unsigned int) ioarg; unsigned int ipcnum = (unsigned int) ioarg;
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_ioctl IOCTL_MW_UNREGISTER_IPC ipcnum %x\n", "mwavedd::mwave_ioctl IOCTL_MW_UNREGISTER_IPC"
" ipcnum %x\n",
ipcnum); ipcnum);
if (ipcnum > 16) { if (ipcnum > ARRAY_SIZE(pDrvData->IPCs)) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::mwave_ioctl: IOCTL_MW_UNREGISTER_IPC: Error: Invalid ipcnum %x\n", ipcnum); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd::mwave_ioctl:"
" IOCTL_MW_UNREGISTER_IPC:"
" Error: Invalid ipcnum %x\n",
ipcnum);
return -EINVAL; return -EINVAL;
} }
if (pDrvData->IPCs[ipcnum].bIsEnabled == TRUE) { if (pDrvData->IPCs[ipcnum].bIsEnabled == TRUE) {
...@@ -355,7 +378,9 @@ static int mwave_ioctl(struct inode *inode, struct file *file, ...@@ -355,7 +378,9 @@ static int mwave_ioctl(struct inode *inode, struct file *file,
break; break;
default: default:
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::mwave_ioctl: Error: Unrecognized iocmd %x\n", iocmd); PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::mwave_ioctl:"
" Error: Unrecognized iocmd %x\n",
iocmd);
return -ENOTTY; return -ENOTTY;
break; break;
} /* switch */ } /* switch */
...@@ -381,7 +406,8 @@ static ssize_t mwave_write(struct file *file, const char *buf, ...@@ -381,7 +406,8 @@ static ssize_t mwave_write(struct file *file, const char *buf,
size_t count, loff_t * ppos) size_t count, loff_t * ppos)
{ {
PRINTK_5(TRACE_MWAVE, PRINTK_5(TRACE_MWAVE,
"mwavedd::mwave_write entry file %p, buf %p, count %x ppos %p\n", "mwavedd::mwave_write entry file %p, buf %p,"
" count %x ppos %p\n",
file, buf, count, ppos); file, buf, count, ppos);
return -EINVAL; return -EINVAL;
...@@ -400,7 +426,9 @@ static int register_serial_portandirq(unsigned int port, int irq) ...@@ -400,7 +426,9 @@ static int register_serial_portandirq(unsigned int port, int irq)
/* OK */ /* OK */
break; break;
default: default:
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::register_serial_portandirq: Error: Illegal port %x\n", port ); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd::register_serial_portandirq:"
" Error: Illegal port %x\n", port );
return -1; return -1;
} /* switch */ } /* switch */
/* port is okay */ /* port is okay */
...@@ -413,7 +441,9 @@ static int register_serial_portandirq(unsigned int port, int irq) ...@@ -413,7 +441,9 @@ static int register_serial_portandirq(unsigned int port, int irq)
/* OK */ /* OK */
break; break;
default: default:
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::register_serial_portandirq: Error: Illegal irq %x\n", irq ); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd::register_serial_portandirq:"
" Error: Illegal irq %x\n", irq );
return -1; return -1;
} /* switch */ } /* switch */
/* irq is okay */ /* irq is okay */
...@@ -427,7 +457,6 @@ static int register_serial_portandirq(unsigned int port, int irq) ...@@ -427,7 +457,6 @@ static int register_serial_portandirq(unsigned int port, int irq)
} }
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0)
static struct file_operations mwave_fops = { static struct file_operations mwave_fops = {
.owner = THIS_MODULE, .owner = THIS_MODULE,
.read = mwave_read, .read = mwave_read,
...@@ -436,23 +465,45 @@ static struct file_operations mwave_fops = { ...@@ -436,23 +465,45 @@ static struct file_operations mwave_fops = {
.open = mwave_open, .open = mwave_open,
.release = mwave_close .release = mwave_close
}; };
#else
static struct file_operations mwave_fops = {
NULL, /* lseek */
mwave_read, /* read */
mwave_write, /* write */
NULL, /* readdir */
NULL, /* poll */
mwave_ioctl, /* ioctl */
NULL, /* mmap */
mwave_open, /* open */
NULL, /* flush */
mwave_close /* release */
};
#endif
static struct miscdevice mwave_misc_dev = { MWAVE_MINOR, "mwave", &mwave_fops }; static struct miscdevice mwave_misc_dev = { MWAVE_MINOR, "mwave", &mwave_fops };
/*
* sysfs support <paulsch@us.ibm.com>
*/
struct device mwave_device;
/* Prevent code redundancy, create a macro for mwave_show_* functions. */
#define mwave_show_function(attr_name, format_string, field) \
static ssize_t mwave_show_##attr_name(struct device *dev, char *buf) \
{ \
DSP_3780I_CONFIG_SETTINGS *pSettings = \
&mwave_s_mdd.rBDData.rDspSettings; \
return sprintf(buf, format_string, pSettings->field); \
}
/* All of our attributes are read attributes. */
#define mwave_dev_rd_attr(attr_name, format_string, field) \
mwave_show_function(attr_name, format_string, field) \
static DEVICE_ATTR(attr_name, S_IRUGO, mwave_show_##attr_name, NULL)
mwave_dev_rd_attr (3780i_dma, "%i\n", usDspDma);
mwave_dev_rd_attr (3780i_irq, "%i\n", usDspIrq);
mwave_dev_rd_attr (3780i_io, "%#.4x\n", usDspBaseIO);
mwave_dev_rd_attr (uart_irq, "%i\n", usUartIrq);
mwave_dev_rd_attr (uart_io, "%#.4x\n", usUartBaseIO);
static struct device_attribute * const mwave_dev_attrs[] = {
&dev_attr_3780i_dma,
&dev_attr_3780i_irq,
&dev_attr_3780i_io,
&dev_attr_uart_irq,
&dev_attr_uart_io,
};
/* /*
* mwave_init is called on module load * mwave_init is called on module load
* *
...@@ -461,17 +512,16 @@ static struct miscdevice mwave_misc_dev = { MWAVE_MINOR, "mwave", &mwave_fops }; ...@@ -461,17 +512,16 @@ static struct miscdevice mwave_misc_dev = { MWAVE_MINOR, "mwave", &mwave_fops };
*/ */
static void mwave_exit(void) static void mwave_exit(void)
{ {
int i;
pMWAVE_DEVICE_DATA pDrvData = &mwave_s_mdd; pMWAVE_DEVICE_DATA pDrvData = &mwave_s_mdd;
PRINTK_1(TRACE_MWAVE, "mwavedd::mwave_exit entry\n"); PRINTK_1(TRACE_MWAVE, "mwavedd::mwave_exit entry\n");
if (pDrvData->bProcEntryCreated) { for (i = 0; i < ARRAY_SIZE(mwave_dev_attrs); i++) {
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0) device_remove_file(&mwave_device, mwave_dev_attrs[i]);
remove_proc_entry("mwave", NULL);
#else
proc_unregister(&proc_root, mwave_proc.low_ino);
#endif
} }
device_unregister(&mwave_device);
if ( pDrvData->sLine >= 0 ) { if ( pDrvData->sLine >= 0 ) {
unregister_serial(pDrvData->sLine); unregister_serial(pDrvData->sLine);
} }
...@@ -497,72 +547,81 @@ static int __init mwave_init(void) ...@@ -497,72 +547,81 @@ static int __init mwave_init(void)
{ {
int i; int i;
int retval = 0; int retval = 0;
unsigned int resultMiscRegister;
pMWAVE_DEVICE_DATA pDrvData = &mwave_s_mdd; pMWAVE_DEVICE_DATA pDrvData = &mwave_s_mdd;
memset(&mwave_s_mdd, 0, sizeof(MWAVE_DEVICE_DATA));
PRINTK_1(TRACE_MWAVE, "mwavedd::mwave_init entry\n"); PRINTK_1(TRACE_MWAVE, "mwavedd::mwave_init entry\n");
memset(&mwave_s_mdd, 0, sizeof(MWAVE_DEVICE_DATA));
pDrvData->bBDInitialized = FALSE; pDrvData->bBDInitialized = FALSE;
pDrvData->bResourcesClaimed = FALSE; pDrvData->bResourcesClaimed = FALSE;
pDrvData->bDSPEnabled = FALSE; pDrvData->bDSPEnabled = FALSE;
pDrvData->bDSPReset = FALSE; pDrvData->bDSPReset = FALSE;
pDrvData->bMwaveDevRegistered = FALSE; pDrvData->bMwaveDevRegistered = FALSE;
pDrvData->sLine = -1; pDrvData->sLine = -1;
pDrvData->bProcEntryCreated = FALSE;
for (i = 0; i < 16; i++) { for (i = 0; i < ARRAY_SIZE(pDrvData->IPCs); i++) {
pDrvData->IPCs[i].bIsEnabled = FALSE; pDrvData->IPCs[i].bIsEnabled = FALSE;
pDrvData->IPCs[i].bIsHere = FALSE; pDrvData->IPCs[i].bIsHere = FALSE;
pDrvData->IPCs[i].usIntCount = 0; /* no ints received yet */ pDrvData->IPCs[i].usIntCount = 0; /* no ints received yet */
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0)
init_waitqueue_head(&pDrvData->IPCs[i].ipc_wait_queue); init_waitqueue_head(&pDrvData->IPCs[i].ipc_wait_queue);
#endif
} }
retval = tp3780I_InitializeBoardData(&pDrvData->rBDData); retval = tp3780I_InitializeBoardData(&pDrvData->rBDData);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_init, return from tp3780I_InitializeBoardData retval %x\n", "mwavedd::mwave_init, return from tp3780I_InitializeBoardData"
" retval %x\n",
retval); retval);
if (retval) { if (retval) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::mwave_init: Error: Failed to initialize board data\n"); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd::mwave_init: Error:"
" Failed to initialize board data\n");
goto cleanup_error; goto cleanup_error;
} }
pDrvData->bBDInitialized = TRUE; pDrvData->bBDInitialized = TRUE;
retval = tp3780I_CalcResources(&pDrvData->rBDData); retval = tp3780I_CalcResources(&pDrvData->rBDData);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_init, return from tp3780I_CalcResources retval %x\n", "mwavedd::mwave_init, return from tp3780I_CalcResources"
" retval %x\n",
retval); retval);
if (retval) { if (retval) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd:mwave_init: Error: Failed to calculate resources\n"); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd:mwave_init: Error:"
" Failed to calculate resources\n");
goto cleanup_error; goto cleanup_error;
} }
retval = tp3780I_ClaimResources(&pDrvData->rBDData); retval = tp3780I_ClaimResources(&pDrvData->rBDData);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_init, return from tp3780I_ClaimResources retval %x\n", "mwavedd::mwave_init, return from tp3780I_ClaimResources"
" retval %x\n",
retval); retval);
if (retval) { if (retval) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd:mwave_init: Error: Failed to claim resources\n"); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd:mwave_init: Error:"
" Failed to claim resources\n");
goto cleanup_error; goto cleanup_error;
} }
pDrvData->bResourcesClaimed = TRUE; pDrvData->bResourcesClaimed = TRUE;
retval = tp3780I_EnableDSP(&pDrvData->rBDData); retval = tp3780I_EnableDSP(&pDrvData->rBDData);
PRINTK_2(TRACE_MWAVE, PRINTK_2(TRACE_MWAVE,
"mwavedd::mwave_init, return from tp3780I_EnableDSP retval %x\n", "mwavedd::mwave_init, return from tp3780I_EnableDSP"
" retval %x\n",
retval); retval);
if (retval) { if (retval) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd:mwave_init: Error: Failed to enable DSP\n"); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd:mwave_init: Error:"
" Failed to enable DSP\n");
goto cleanup_error; goto cleanup_error;
} }
pDrvData->bDSPEnabled = TRUE; pDrvData->bDSPEnabled = TRUE;
resultMiscRegister = misc_register(&mwave_misc_dev); if (misc_register(&mwave_misc_dev) < 0) {
if (resultMiscRegister < 0) { PRINTK_ERROR(KERN_ERR_MWAVE
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd:mwave_init: Error: Failed to register misc device\n"); "mwavedd:mwave_init: Error:"
" Failed to register misc device\n");
goto cleanup_error; goto cleanup_error;
} }
pDrvData->bMwaveDevRegistered = TRUE; pDrvData->bMwaveDevRegistered = TRUE;
...@@ -572,28 +631,36 @@ static int __init mwave_init(void) ...@@ -572,28 +631,36 @@ static int __init mwave_init(void)
pDrvData->rBDData.rDspSettings.usUartIrq pDrvData->rBDData.rDspSettings.usUartIrq
); );
if (pDrvData->sLine < 0) { if (pDrvData->sLine < 0) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd:mwave_init: Error: Failed to register serial driver\n"); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd:mwave_init: Error:"
" Failed to register serial driver\n");
goto cleanup_error; goto cleanup_error;
} }
/* uart is registered */ /* uart is registered */
if ( /* sysfs */
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0) memset(&mwave_device, 0, sizeof (struct device));
!create_proc_info_entry("mwave", 0, NULL, mwave_get_info) snprintf(mwave_device.name, DEVICE_NAME_SIZE, "mwave");
#else snprintf(mwave_device.bus_id, BUS_ID_SIZE, "mwave");
proc_register(&proc_root, &mwave_proc)
#endif device_register(&mwave_device);
) { for (i = 0; i < ARRAY_SIZE(mwave_dev_attrs); i++) {
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::mwave_init: Error: Failed to register /proc/mwave\n"); if(device_create_file(&mwave_device, mwave_dev_attrs[i])) {
goto cleanup_error; PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd:mwave_init: Error:"
" Failed to create sysfs file %s\n",
mwave_dev_attrs[i]->attr.name);
goto cleanup_error;
}
} }
pDrvData->bProcEntryCreated = TRUE;
/* SUCCESS! */ /* SUCCESS! */
return 0; return 0;
cleanup_error: cleanup_error:
PRINTK_ERROR(KERN_ERR_MWAVE "mwavedd::mwave_init: Error: Failed to initialize\n"); PRINTK_ERROR(KERN_ERR_MWAVE
"mwavedd::mwave_init: Error:"
" Failed to initialize\n");
mwave_exit(); /* clean up */ mwave_exit(); /* clean up */
return -EIO; return -EIO;
...@@ -601,39 +668,3 @@ static int __init mwave_init(void) ...@@ -601,39 +668,3 @@ static int __init mwave_init(void)
module_init(mwave_init); module_init(mwave_init);
/*
* proc entry stuff added by Ian Pilcher <pilcher@us.ibm.com>
*/
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0)
static int mwave_get_info(char *buf, char **start, off_t offset, int len)
{
DSP_3780I_CONFIG_SETTINGS *pSettings = &mwave_s_mdd.rBDData.rDspSettings;
char *out = buf;
out += sprintf(out, "3780i_IRQ %i\n", pSettings->usDspIrq);
out += sprintf(out, "3780i_DMA %i\n", pSettings->usDspDma);
out += sprintf(out, "3780i_IO %#.4x\n", pSettings->usDspBaseIO);
out += sprintf(out, "UART_IRQ %i\n", pSettings->usUartIrq);
out += sprintf(out, "UART_IO %#.4x\n", pSettings->usUartBaseIO);
return out - buf;
}
#else /* kernel version < 2.4.0 */
static int mwave_read_proc(char *buf, char **start, off_t offset,
int xlen, int unused)
{
DSP_3780I_CONFIG_SETTINGS *pSettings = &mwave_s_mdd.rBDData.rDspSettings;
int len;
len = sprintf(buf, "3780i_IRQ %i\n", pSettings->usDspIrq);
len += sprintf(&buf[len], "3780i_DMA %i\n", pSettings->usDspDma);
len += sprintf(&buf[len], "3780i_IO %#.4x\n", pSettings->usDspBaseIO);
len += sprintf(&buf[len], "UART_IRQ %i\n", pSettings->usUartIrq);
len += sprintf(&buf[len], "UART_IO %#.4x\n", pSettings->usUartBaseIO);
return len;
}
#endif
...@@ -126,11 +126,7 @@ typedef struct _MWAVE_IPC { ...@@ -126,11 +126,7 @@ typedef struct _MWAVE_IPC {
BOOLEAN bIsEnabled; BOOLEAN bIsEnabled;
BOOLEAN bIsHere; BOOLEAN bIsHere;
/* entry spin lock */ /* entry spin lock */
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,4,0)
wait_queue_head_t ipc_wait_queue; wait_queue_head_t ipc_wait_queue;
#else
struct wait_queue *ipc_wait_queue;
#endif
} MWAVE_IPC; } MWAVE_IPC;
typedef struct _MWAVE_DEVICE_DATA { typedef struct _MWAVE_DEVICE_DATA {
...@@ -143,7 +139,6 @@ typedef struct _MWAVE_DEVICE_DATA { ...@@ -143,7 +139,6 @@ typedef struct _MWAVE_DEVICE_DATA {
BOOLEAN bDSPReset; BOOLEAN bDSPReset;
MWAVE_IPC IPCs[16]; MWAVE_IPC IPCs[16];
BOOLEAN bMwaveDevRegistered; BOOLEAN bMwaveDevRegistered;
BOOLEAN bProcEntryCreated;
short sLine; short sLine;
} MWAVE_DEVICE_DATA, *pMWAVE_DEVICE_DATA; } MWAVE_DEVICE_DATA, *pMWAVE_DEVICE_DATA;
......
...@@ -50,13 +50,8 @@ ...@@ -50,13 +50,8 @@
#ifndef _LINUX_MWAVEPUB_H #ifndef _LINUX_MWAVEPUB_H
#define _LINUX_MWAVEPUB_H #define _LINUX_MWAVEPUB_H
#ifndef MWAVEM_APP_DIST
#include <linux/miscdevice.h> #include <linux/miscdevice.h>
#endif
#ifdef MWAVEM_APP_DIST
#define MWAVE_MINOR 219
#endif
typedef struct _MW_ABILITIES { typedef struct _MW_ABILITIES {
unsigned long instr_per_sec; unsigned long instr_per_sec;
......
...@@ -280,10 +280,11 @@ int smapi_set_DSP_cfg(void) ...@@ -280,10 +280,11 @@ int smapi_set_DSP_cfg(void)
if ((usSI & 0xFF) == mwave_uart_irq) { if ((usSI & 0xFF) == mwave_uart_irq) {
#ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_ERROR(KERN_ERR_MWAVE PRINTK_ERROR(KERN_ERR_MWAVE
"smapi::smapi_set_DSP_cfg: Serial port A irq %x conflicts with mwave_uart_irq %x\n", usSI & 0xFF, mwave_uart_irq);
#else #else
PRINTK_3(TRACE_SMAPI, PRINTK_3(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg: Serial port A irq %x conflicts with mwave_uart_irq %x\n", usSI & 0xFF, mwave_uart_irq);
#endif #endif
"smapi::smapi_set_DSP_cfg: Serial port A irq %x conflicts with mwave_uart_irq %x\n", usSI, mwave_uart_irq);
#ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_1(TRACE_SMAPI, PRINTK_1(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg Disabling conflicting serial port\n"); "smapi::smapi_set_DSP_cfg Disabling conflicting serial port\n");
...@@ -300,13 +301,14 @@ int smapi_set_DSP_cfg(void) ...@@ -300,13 +301,14 @@ int smapi_set_DSP_cfg(void)
if ((usSI >> 8) == uartio_index) { if ((usSI >> 8) == uartio_index) {
#ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_ERROR(KERN_ERR_MWAVE PRINTK_ERROR(KERN_ERR_MWAVE
"smapi::smapi_set_DSP_cfg: Serial port A base I/O address %x conflicts with mwave uart I/O %x\n", ausUartBases[usSI >> 8], ausUartBases[uartio_index]);
#else #else
PRINTK_3(TRACE_SMAPI, PRINTK_3(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg: Serial port A base I/O address %x conflicts with mwave uart I/O %x\n", ausUartBases[usSI >> 8], ausUartBases[uartio_index]);
#endif #endif
"smapi::smapi_set_DSP_cfg: Serial port A base I/O address index %x conflicts with uartio_index %x\n", usSI >> 8, uartio_index);
#ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_1(TRACE_SMAPI, PRINTK_1(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg Disabling conflicting serial port\n"); "smapi::smapi_set_DSP_cfg Disabling conflicting serial port A\n");
bRC = smapi_request (0x1403, 0x0100, 0, usSI, bRC = smapi_request (0x1403, 0x0100, 0, usSI,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI); &usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error; if (bRC) goto exit_smapi_request_error;
...@@ -331,13 +333,14 @@ int smapi_set_DSP_cfg(void) ...@@ -331,13 +333,14 @@ int smapi_set_DSP_cfg(void)
if ((usSI & 0xFF) == mwave_uart_irq) { if ((usSI & 0xFF) == mwave_uart_irq) {
#ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_ERROR(KERN_ERR_MWAVE PRINTK_ERROR(KERN_ERR_MWAVE
"smapi::smapi_set_DSP_cfg: Serial port B irq %x conflicts with mwave_uart_irq %x\n", usSI & 0xFF, mwave_uart_irq);
#else #else
PRINTK_3(TRACE_SMAPI, PRINTK_3(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg: Serial port B irq %x conflicts with mwave_uart_irq %x\n", usSI & 0xFF, mwave_uart_irq);
#endif #endif
"smapi::smapi_set_DSP_cfg: Serial port B irq %x conflicts with mwave_uart_irq %x\n", usSI, mwave_uart_irq);
#ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_1(TRACE_SMAPI, PRINTK_1(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg Disabling conflicting serial port\n"); "smapi::smapi_set_DSP_cfg Disabling conflicting serial port B\n");
bRC = smapi_request(0x1405, 0x0100, 0, usSI, bRC = smapi_request(0x1405, 0x0100, 0, usSI,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI); &usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error; if (bRC) goto exit_smapi_request_error;
...@@ -351,13 +354,14 @@ int smapi_set_DSP_cfg(void) ...@@ -351,13 +354,14 @@ int smapi_set_DSP_cfg(void)
if ((usSI >> 8) == uartio_index) { if ((usSI >> 8) == uartio_index) {
#ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_ERROR(KERN_ERR_MWAVE PRINTK_ERROR(KERN_ERR_MWAVE
"smapi::smapi_set_DSP_cfg: Serial port B base I/O address %x conflicts with mwave uart I/O %x\n", ausUartBases[usSI >> 8], ausUartBases[uartio_index]);
#else #else
PRINTK_3(TRACE_SMAPI, PRINTK_3(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg: Serial port B base I/O address %x conflicts with mwave uart I/O %x\n", ausUartBases[usSI >> 8], ausUartBases[uartio_index]);
#endif #endif
"smapi::smapi_set_DSP_cfg: Serial port B base I/O address index %x conflicts with uartio_index %x\n", usSI >> 8, uartio_index);
#ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_1 (TRACE_SMAPI, PRINTK_1 (TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg Disabling conflicting serial port\n"); "smapi::smapi_set_DSP_cfg Disabling conflicting serial port B\n");
bRC = smapi_request (0x1405, 0x0100, 0, usSI, bRC = smapi_request (0x1405, 0x0100, 0, usSI,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI); &usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error; if (bRC) goto exit_smapi_request_error;
...@@ -380,39 +384,15 @@ int smapi_set_DSP_cfg(void) ...@@ -380,39 +384,15 @@ int smapi_set_DSP_cfg(void)
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI); &usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error; if (bRC) goto exit_smapi_request_error;
/* bRC == 0 */ /* bRC == 0 */
if ((usCX & 0xff) == mwave_uart_irq) { /* serial port is enabled */ if ((usCX & 0xff) != 0xff) { /* IR port not disabled */
#ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES if ((usCX & 0xff) == mwave_uart_irq) {
PRINTK_ERROR(KERN_ERR_MWAVE
#else
PRINTK_3(TRACE_SMAPI,
#endif
"smapi::smapi_set_DSP_cfg: IR port irq %x conflicts with mwave_uart_irq %x\n", usSI, mwave_uart_irq);
#ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_1(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg Disabling conflicting IR port\n");
bRC = smapi_request(0x1701, 0x0100, 0, 0,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error;
bRC = smapi_request(0x1700, 0, 0, 0,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error;
bRC = smapi_request(0x1705, 0x01ff, 0, usSI,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error;
bRC = smapi_request(0x1704, 0x0000, 0, 0,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error;
#else
goto exit_conflict;
#endif
} else {
if ((usSI & 0xff) == uartio_index) {
#ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_ERROR(KERN_ERR_MWAVE PRINTK_ERROR(KERN_ERR_MWAVE
"smapi::smapi_set_DSP_cfg: IR port irq %x conflicts with mwave_uart_irq %x\n", usCX & 0xff, mwave_uart_irq);
#else #else
PRINTK_3(TRACE_SMAPI, PRINTK_3(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg: IR port irq %x conflicts with mwave_uart_irq %x\n", usCX & 0xff, mwave_uart_irq);
#endif #endif
"smapi::smapi_set_DSP_cfg: IR port base I/O address index %x conflicts with uartio_index %x\n", usSI & 0xff, uartio_index);
#ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES #ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_1(TRACE_SMAPI, PRINTK_1(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg Disabling conflicting IR port\n"); "smapi::smapi_set_DSP_cfg Disabling conflicting IR port\n");
...@@ -431,6 +411,34 @@ int smapi_set_DSP_cfg(void) ...@@ -431,6 +411,34 @@ int smapi_set_DSP_cfg(void)
#else #else
goto exit_conflict; goto exit_conflict;
#endif #endif
} else {
if ((usSI & 0xff) == uartio_index) {
#ifndef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_ERROR(KERN_ERR_MWAVE
"smapi::smapi_set_DSP_cfg: IR port base I/O address %x conflicts with mwave uart I/O %x\n", ausUartBases[usSI & 0xff], ausUartBases[uartio_index]);
#else
PRINTK_3(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg: IR port base I/O address %x conflicts with mwave uart I/O %x\n", ausUartBases[usSI & 0xff], ausUartBases[uartio_index]);
#endif
#ifdef MWAVE_FUTZ_WITH_OTHER_DEVICES
PRINTK_1(TRACE_SMAPI,
"smapi::smapi_set_DSP_cfg Disabling conflicting IR port\n");
bRC = smapi_request(0x1701, 0x0100, 0, 0,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error;
bRC = smapi_request(0x1700, 0, 0, 0,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error;
bRC = smapi_request(0x1705, 0x01ff, 0, usSI,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error;
bRC = smapi_request(0x1704, 0x0000, 0, 0,
&usAX, &usBX, &usCX, &usDX, &usDI, &usSI);
if (bRC) goto exit_smapi_request_error;
#else
goto exit_conflict;
#endif
}
} }
} }
} }
......
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