| File: | drivers/char/mwave/mwavedd.c |
| Warning: | line 177, column 9 Copies out a struct with uncleared padding (>= 4 bytes) |
| 1 | /* | |||
| 2 | * | |||
| 3 | * mwavedd.c -- mwave device driver | |||
| 4 | * | |||
| 5 | * | |||
| 6 | * Written By: Mike Sullivan IBM Corporation | |||
| 7 | * | |||
| 8 | * Copyright (C) 1999 IBM Corporation | |||
| 9 | * | |||
| 10 | * This program is free software; you can redistribute it and/or modify | |||
| 11 | * it under the terms of the GNU General Public License as published by | |||
| 12 | * the Free Software Foundation; either version 2 of the License, or | |||
| 13 | * (at your option) any later version. | |||
| 14 | * | |||
| 15 | * This program is distributed in the hope that it will be useful, | |||
| 16 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |||
| 17 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |||
| 18 | * GNU General Public License for more details. | |||
| 19 | * | |||
| 20 | * NO WARRANTY | |||
| 21 | * THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR | |||
| 22 | * CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT | |||
| 23 | * LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT, | |||
| 24 | * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is | |||
| 25 | * solely responsible for determining the appropriateness of using and | |||
| 26 | * distributing the Program and assumes all risks associated with its | |||
| 27 | * exercise of rights under this Agreement, including but not limited to | |||
| 28 | * the risks and costs of program errors, damage to or loss of data, | |||
| 29 | * programs or equipment, and unavailability or interruption of operations. | |||
| 30 | * | |||
| 31 | * DISCLAIMER OF LIABILITY | |||
| 32 | * NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY | |||
| 33 | * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |||
| 34 | * DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND | |||
| 35 | * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR | |||
| 36 | * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE | |||
| 37 | * USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED | |||
| 38 | * HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES | |||
| 39 | * | |||
| 40 | * You should have received a copy of the GNU General Public License | |||
| 41 | * along with this program; if not, write to the Free Software | |||
| 42 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |||
| 43 | * | |||
| 44 | * | |||
| 45 | * 10/23/2000 - Alpha Release | |||
| 46 | * First release to the public | |||
| 47 | */ | |||
| 48 | ||||
| 49 | #include <linux1/module.h> | |||
| 50 | #include <linux1/kernel.h> | |||
| 51 | #include <linux1/fs.h> | |||
| 52 | #include <linux1/init.h> | |||
| 53 | #include <linux1/major.h> | |||
| 54 | #include <linux1/miscdevice.h> | |||
| 55 | #include <linux1/device.h> | |||
| 56 | #include <linux1/serial.h> | |||
| 57 | #include <linux1/sched.h> | |||
| 58 | #include <linux1/spinlock.h> | |||
| 59 | #include <linux1/mutex.h> | |||
| 60 | #include <linux1/delay.h> | |||
| 61 | #include <linux1/serial_8250.h> | |||
| 62 | #include "smapi.h" | |||
| 63 | #include "mwavedd.h" | |||
| 64 | #include "3780i.h" | |||
| 65 | #include "tp3780i.h" | |||
| 66 | ||||
| 67 | MODULE_DESCRIPTION("3780i Advanced Communications Processor (Mwave) driver")struct __UNIQUE_ID_description20 {}; | |||
| 68 | MODULE_AUTHOR("Mike Sullivan and Paul Schroeder")struct __UNIQUE_ID_author21 {}; | |||
| 69 | MODULE_LICENSE("GPL")struct __UNIQUE_ID_license22 {}; | |||
| 70 | ||||
| 71 | /* | |||
| 72 | * These parameters support the setting of MWave resources. Note that no | |||
| 73 | * checks are made against other devices (ie. superio) for conflicts. | |||
| 74 | * We'll depend on users using the tpctl utility to do that for now | |||
| 75 | */ | |||
| 76 | static DEFINE_MUTEX(mwave_mutex)struct mutex mwave_mutex = { .count = { (1) } , .wait_lock = ( spinlock_t ) { { .rlock = { .raw_lock = { { (0) } }, .magic = 0xdead4ead, .owner_cpu = -1, .owner = ((void *)-1L), .dep_map = { .name = "mwave_mutex.wait_lock" } } } } , .wait_list = { &(mwave_mutex.wait_list), &(mwave_mutex.wait_list) } , .magic = &mwave_mutex , .dep_map = { .name = "mwave_mutex" } }; | |||
| 77 | int mwave_debug = 0; | |||
| 78 | int mwave_3780i_irq = 0; | |||
| 79 | int mwave_3780i_io = 0; | |||
| 80 | int mwave_uart_irq = 0; | |||
| 81 | int mwave_uart_io = 0; | |||
| 82 | module_param(mwave_debug, int, 0)static inline __attribute__((no_instrument_function)) int __attribute__ ((unused)) *__check_mwave_debug(void) { return(&(mwave_debug )); }; static const char __param_str_mwave_debug[] = "mwave" "." "mwave_debug"; static struct kernel_param const __param_mwave_debug __attribute__((__used__)) __attribute__ ((unused,__section__ ("__param"),aligned(sizeof(void *)))) = { __param_str_mwave_debug , ((struct module *)0), ¶m_ops_int, ((sizeof(struct { int:-!!((0) < 0); })) + (sizeof(struct { int:-!!((0) > 0777); })) + (sizeof(struct { int:-!!((((0) >> 6) & 4) < (((0) >> 3) & 4)); })) + (sizeof(struct { int :-!!((((0) >> 3) & 4) < ((0) & 4)); })) + (sizeof (struct { int:-!!((((0) >> 6) & 2) < (((0) >> 3) & 2)); })) + (sizeof(struct { int:-!!((0) & 2); } )) + (0)), -1, 0, { &mwave_debug } }; struct __UNIQUE_ID_mwave_debugtype23 {}; | |||
| 83 | module_param(mwave_3780i_irq, int, 0)static inline __attribute__((no_instrument_function)) int __attribute__ ((unused)) *__check_mwave_3780i_irq(void) { return(&(mwave_3780i_irq )); }; static const char __param_str_mwave_3780i_irq[] = "mwave" "." "mwave_3780i_irq"; static struct kernel_param const __param_mwave_3780i_irq __attribute__((__used__)) __attribute__ ((unused,__section__ ("__param"),aligned(sizeof(void *)))) = { __param_str_mwave_3780i_irq , ((struct module *)0), ¶m_ops_int, ((sizeof(struct { int:-!!((0) < 0); })) + (sizeof(struct { int:-!!((0) > 0777); })) + (sizeof(struct { int:-!!((((0) >> 6) & 4) < (((0) >> 3) & 4)); })) + (sizeof(struct { int :-!!((((0) >> 3) & 4) < ((0) & 4)); })) + (sizeof (struct { int:-!!((((0) >> 6) & 2) < (((0) >> 3) & 2)); })) + (sizeof(struct { int:-!!((0) & 2); } )) + (0)), -1, 0, { &mwave_3780i_irq } }; struct __UNIQUE_ID_mwave_3780i_irqtype24 {}; | |||
| 84 | module_param(mwave_3780i_io, int, 0)static inline __attribute__((no_instrument_function)) int __attribute__ ((unused)) *__check_mwave_3780i_io(void) { return(&(mwave_3780i_io )); }; static const char __param_str_mwave_3780i_io[] = "mwave" "." "mwave_3780i_io"; static struct kernel_param const __param_mwave_3780i_io __attribute__((__used__)) __attribute__ ((unused,__section__ ("__param"),aligned(sizeof(void *)))) = { __param_str_mwave_3780i_io , ((struct module *)0), ¶m_ops_int, ((sizeof(struct { int:-!!((0) < 0); })) + (sizeof(struct { int:-!!((0) > 0777); })) + (sizeof(struct { int:-!!((((0) >> 6) & 4) < (((0) >> 3) & 4)); })) + (sizeof(struct { int :-!!((((0) >> 3) & 4) < ((0) & 4)); })) + (sizeof (struct { int:-!!((((0) >> 6) & 2) < (((0) >> 3) & 2)); })) + (sizeof(struct { int:-!!((0) & 2); } )) + (0)), -1, 0, { &mwave_3780i_io } }; struct __UNIQUE_ID_mwave_3780i_iotype25 {}; | |||
| 85 | module_param(mwave_uart_irq, int, 0)static inline __attribute__((no_instrument_function)) int __attribute__ ((unused)) *__check_mwave_uart_irq(void) { return(&(mwave_uart_irq )); }; static const char __param_str_mwave_uart_irq[] = "mwave" "." "mwave_uart_irq"; static struct kernel_param const __param_mwave_uart_irq __attribute__((__used__)) __attribute__ ((unused,__section__ ("__param"),aligned(sizeof(void *)))) = { __param_str_mwave_uart_irq , ((struct module *)0), ¶m_ops_int, ((sizeof(struct { int:-!!((0) < 0); })) + (sizeof(struct { int:-!!((0) > 0777); })) + (sizeof(struct { int:-!!((((0) >> 6) & 4) < (((0) >> 3) & 4)); })) + (sizeof(struct { int :-!!((((0) >> 3) & 4) < ((0) & 4)); })) + (sizeof (struct { int:-!!((((0) >> 6) & 2) < (((0) >> 3) & 2)); })) + (sizeof(struct { int:-!!((0) & 2); } )) + (0)), -1, 0, { &mwave_uart_irq } }; struct __UNIQUE_ID_mwave_uart_irqtype26 {}; | |||
| 86 | module_param(mwave_uart_io, int, 0)static inline __attribute__((no_instrument_function)) int __attribute__ ((unused)) *__check_mwave_uart_io(void) { return(&(mwave_uart_io )); }; static const char __param_str_mwave_uart_io[] = "mwave" "." "mwave_uart_io"; static struct kernel_param const __param_mwave_uart_io __attribute__((__used__)) __attribute__ ((unused,__section__ ("__param"),aligned(sizeof(void *)))) = { __param_str_mwave_uart_io , ((struct module *)0), ¶m_ops_int, ((sizeof(struct { int:-!!((0) < 0); })) + (sizeof(struct { int:-!!((0) > 0777); })) + (sizeof(struct { int:-!!((((0) >> 6) & 4) < (((0) >> 3) & 4)); })) + (sizeof(struct { int :-!!((((0) >> 3) & 4) < ((0) & 4)); })) + (sizeof (struct { int:-!!((((0) >> 6) & 2) < (((0) >> 3) & 2)); })) + (sizeof(struct { int:-!!((0) & 2); } )) + (0)), -1, 0, { &mwave_uart_io } }; struct __UNIQUE_ID_mwave_uart_iotype27 {}; | |||
| 87 | ||||
| 88 | static int mwave_open(struct inode *inode, struct file *file); | |||
| 89 | static int mwave_close(struct inode *inode, struct file *file); | |||
| 90 | static long mwave_ioctl(struct file *filp, unsigned int iocmd, | |||
| 91 | unsigned long ioarg); | |||
| 92 | ||||
| 93 | MWAVE_DEVICE_DATA mwave_s_mdd; | |||
| 94 | ||||
| 95 | static int mwave_open(struct inode *inode, struct file *file) | |||
| 96 | { | |||
| 97 | unsigned int retval = 0; | |||
| 98 | ||||
| 99 | PRINTK_3(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_open, entry inode %p file %p\n" ,inode,file); } | |||
| 100 | "mwavedd::mwave_open, entry inode %p file %p\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_open, entry inode %p file %p\n" ,inode,file); } | |||
| 101 | inode, file)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_open, entry inode %p file %p\n" ,inode,file); }; | |||
| 102 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_open, exit return retval %x\n" ,retval); } | |||
| 103 | "mwavedd::mwave_open, exit return retval %x\n", retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_open, exit return retval %x\n" ,retval); }; | |||
| 104 | ||||
| 105 | return retval; | |||
| 106 | } | |||
| 107 | ||||
| 108 | static int mwave_close(struct inode *inode, struct file *file) | |||
| 109 | { | |||
| 110 | unsigned int retval = 0; | |||
| 111 | ||||
| 112 | PRINTK_3(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_close, entry inode %p file %p\n" ,inode,file); } | |||
| 113 | "mwavedd::mwave_close, entry inode %p file %p\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_close, entry inode %p file %p\n" ,inode,file); } | |||
| 114 | inode, file)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_close, entry inode %p file %p\n" ,inode,file); }; | |||
| 115 | ||||
| 116 | PRINTK_2(TRACE_MWAVE, "mwavedd::mwave_close, exit retval %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_close, exit retval %x\n" ,retval); } | |||
| 117 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_close, exit retval %x\n" ,retval); }; | |||
| 118 | ||||
| 119 | return retval; | |||
| 120 | } | |||
| 121 | ||||
| 122 | static long mwave_ioctl(struct file *file, unsigned int iocmd, | |||
| 123 | unsigned long ioarg) | |||
| 124 | { | |||
| 125 | unsigned int retval = 0; | |||
| 126 | pMWAVE_DEVICE_DATA pDrvData = &mwave_s_mdd; | |||
| 127 | void __user *arg = (void __user *)ioarg; | |||
| 128 | ||||
| 129 | PRINTK_4(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, entry file %p cmd %x arg %x\n" ,file,iocmd,(int) ioarg); } | |||
| 130 | "mwavedd::mwave_ioctl, entry file %p cmd %x arg %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, entry file %p cmd %x arg %x\n" ,file,iocmd,(int) ioarg); } | |||
| 131 | file, iocmd, (int) ioarg)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, entry file %p cmd %x arg %x\n" ,file,iocmd,(int) ioarg); }; | |||
| 132 | ||||
| 133 | switch (iocmd) { | |||
| ||||
| 134 | ||||
| 135 | case IOCTL_MW_RESET(((0U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((1)) << 0) | ((0) << ((0 +8)+8))): | |||
| 136 | PRINTK_1(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RESET" " calling tp3780I_ResetDSP\n"); } | |||
| 137 | "mwavedd::mwave_ioctl, IOCTL_MW_RESET"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RESET" " calling tp3780I_ResetDSP\n"); } | |||
| 138 | " calling tp3780I_ResetDSP\n")if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RESET" " calling tp3780I_ResetDSP\n"); }; | |||
| 139 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 140 | retval = tp3780I_ResetDSP(&pDrvData->rBDData); | |||
| 141 | mutex_unlock(&mwave_mutex); | |||
| 142 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RESET" " retval %x from tp3780I_ResetDSP\n",retval); } | |||
| 143 | "mwavedd::mwave_ioctl, IOCTL_MW_RESET"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RESET" " retval %x from tp3780I_ResetDSP\n",retval); } | |||
| 144 | " retval %x from tp3780I_ResetDSP\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RESET" " retval %x from tp3780I_ResetDSP\n",retval); } | |||
| 145 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RESET" " retval %x from tp3780I_ResetDSP\n",retval); }; | |||
| 146 | break; | |||
| 147 | ||||
| 148 | case IOCTL_MW_RUN(((0U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((2)) << 0) | ((0) << ((0 +8)+8))): | |||
| 149 | PRINTK_1(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RUN" " calling tp3780I_StartDSP\n"); } | |||
| 150 | "mwavedd::mwave_ioctl, IOCTL_MW_RUN"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RUN" " calling tp3780I_StartDSP\n"); } | |||
| 151 | " calling tp3780I_StartDSP\n")if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RUN" " calling tp3780I_StartDSP\n"); }; | |||
| 152 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 153 | retval = tp3780I_StartDSP(&pDrvData->rBDData); | |||
| 154 | mutex_unlock(&mwave_mutex); | |||
| 155 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RUN" " retval %x from tp3780I_StartDSP\n",retval); } | |||
| 156 | "mwavedd::mwave_ioctl, IOCTL_MW_RUN"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RUN" " retval %x from tp3780I_StartDSP\n",retval); } | |||
| 157 | " retval %x from tp3780I_StartDSP\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RUN" " retval %x from tp3780I_StartDSP\n",retval); } | |||
| 158 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_RUN" " retval %x from tp3780I_StartDSP\n",retval); }; | |||
| 159 | break; | |||
| 160 | ||||
| 161 | case IOCTL_MW_DSP_ABILITIES(((2U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((3)) << 0) | (((((sizeof(MW_ABILITIES) == sizeof(MW_ABILITIES [1]) && sizeof(MW_ABILITIES) < (1 << 14)) ? sizeof (MW_ABILITIES) : __invalid_size_argument_for_IOC))) << ( (0 +8)+8))): { | |||
| 162 | MW_ABILITIES rAbilities; | |||
| 163 | ||||
| 164 | PRINTK_1(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl," " IOCTL_MW_DSP_ABILITIES calling" " tp3780I_QueryAbilities\n" ); } | |||
| 165 | "mwavedd::mwave_ioctl,"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl," " IOCTL_MW_DSP_ABILITIES calling" " tp3780I_QueryAbilities\n" ); } | |||
| 166 | " IOCTL_MW_DSP_ABILITIES calling"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl," " IOCTL_MW_DSP_ABILITIES calling" " tp3780I_QueryAbilities\n" ); } | |||
| 167 | " tp3780I_QueryAbilities\n")if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl," " IOCTL_MW_DSP_ABILITIES calling" " tp3780I_QueryAbilities\n" ); }; | |||
| 168 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 169 | retval = tp3780I_QueryAbilities(&pDrvData->rBDData, | |||
| 170 | &rAbilities); | |||
| 171 | mutex_unlock(&mwave_mutex); | |||
| 172 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES" " retval %x from tp3780I_QueryAbilities\n",retval); } | |||
| 173 | "mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES" " retval %x from tp3780I_QueryAbilities\n",retval); } | |||
| 174 | " retval %x from tp3780I_QueryAbilities\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES" " retval %x from tp3780I_QueryAbilities\n",retval); } | |||
| 175 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES" " retval %x from tp3780I_QueryAbilities\n",retval); }; | |||
| 176 | if (retval == 0) { | |||
| 177 | if( copy_to_user(arg, &rAbilities, | |||
| ||||
| 178 | sizeof(MW_ABILITIES)) ) | |||
| 179 | return -EFAULT14; | |||
| 180 | } | |||
| 181 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES" " exit retval %x\n",retval); } | |||
| 182 | "mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES" " exit retval %x\n",retval); } | |||
| 183 | " exit retval %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES" " exit retval %x\n",retval); } | |||
| 184 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, IOCTL_MW_DSP_ABILITIES" " exit retval %x\n",retval); }; | |||
| 185 | } | |||
| 186 | break; | |||
| 187 | ||||
| 188 | case IOCTL_MW_READ_DATA(((2U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((4)) << 0) | (((((sizeof(MW_READWRITE) == sizeof(MW_READWRITE [1]) && sizeof(MW_READWRITE) < (1 << 14)) ? sizeof (MW_READWRITE) : __invalid_size_argument_for_IOC))) << ( (0 +8)+8))): | |||
| 189 | case IOCTL_MW_READCLEAR_DATA(((2U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((5)) << 0) | (((((sizeof(MW_READWRITE) == sizeof(MW_READWRITE [1]) && sizeof(MW_READWRITE) < (1 << 14)) ? sizeof (MW_READWRITE) : __invalid_size_argument_for_IOC))) << ( (0 +8)+8))): { | |||
| 190 | MW_READWRITE rReadData; | |||
| 191 | unsigned short __user *pusBuffer = NULL((void *)0); | |||
| 192 | ||||
| 193 | if( copy_from_user(&rReadData, arg, | |||
| 194 | sizeof(MW_READWRITE)) ) | |||
| 195 | return -EFAULT14; | |||
| 196 | pusBuffer = (unsigned short __user *) (rReadData.pBuf); | |||
| 197 | ||||
| 198 | PRINTK_4(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength ,ioarg,pusBuffer); } | |||
| 199 | "mwavedd::mwave_ioctl IOCTL_MW_READ_DATA,"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength ,ioarg,pusBuffer); } | |||
| 200 | " size %lx, ioarg %lx pusBuffer %p\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength ,ioarg,pusBuffer); } | |||
| 201 | rReadData.ulDataLength, ioarg, pusBuffer)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength ,ioarg,pusBuffer); }; | |||
| 202 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 203 | retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData, | |||
| 204 | iocmd, | |||
| 205 | pusBuffer, | |||
| 206 | rReadData.ulDataLength, | |||
| 207 | rReadData.usDspAddress); | |||
| 208 | mutex_unlock(&mwave_mutex); | |||
| 209 | } | |||
| 210 | break; | |||
| 211 | ||||
| 212 | case IOCTL_MW_READ_INST(((2U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((6)) << 0) | (((((sizeof(MW_READWRITE) == sizeof(MW_READWRITE [1]) && sizeof(MW_READWRITE) < (1 << 14)) ? sizeof (MW_READWRITE) : __invalid_size_argument_for_IOC))) << ( (0 +8)+8))): { | |||
| 213 | MW_READWRITE rReadData; | |||
| 214 | unsigned short __user *pusBuffer = NULL((void *)0); | |||
| 215 | ||||
| 216 | if( copy_from_user(&rReadData, arg, | |||
| 217 | sizeof(MW_READWRITE)) ) | |||
| 218 | return -EFAULT14; | |||
| 219 | pusBuffer = (unsigned short __user *) (rReadData.pBuf); | |||
| 220 | ||||
| 221 | PRINTK_4(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_INST," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength / 2,ioarg,pusBuffer); } | |||
| 222 | "mwavedd::mwave_ioctl IOCTL_MW_READ_INST,"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_INST," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength / 2,ioarg,pusBuffer); } | |||
| 223 | " size %lx, ioarg %lx pusBuffer %p\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_INST," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength / 2,ioarg,pusBuffer); } | |||
| 224 | rReadData.ulDataLength / 2, ioarg,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_INST," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength / 2,ioarg,pusBuffer); } | |||
| 225 | pusBuffer)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_READ_INST," " size %lx, ioarg %lx pusBuffer %p\n",rReadData.ulDataLength / 2,ioarg,pusBuffer); }; | |||
| 226 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 227 | retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData, | |||
| 228 | iocmd, pusBuffer, | |||
| 229 | rReadData.ulDataLength / 2, | |||
| 230 | rReadData.usDspAddress); | |||
| 231 | mutex_unlock(&mwave_mutex); | |||
| 232 | } | |||
| 233 | break; | |||
| 234 | ||||
| 235 | case IOCTL_MW_WRITE_DATA(((1U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((7)) << 0) | (((((sizeof(MW_READWRITE) == sizeof(MW_READWRITE [1]) && sizeof(MW_READWRITE) < (1 << 14)) ? sizeof (MW_READWRITE) : __invalid_size_argument_for_IOC))) << ( (0 +8)+8))): { | |||
| 236 | MW_READWRITE rWriteData; | |||
| 237 | unsigned short __user *pusBuffer = NULL((void *)0); | |||
| 238 | ||||
| 239 | if( copy_from_user(&rWriteData, arg, | |||
| 240 | sizeof(MW_READWRITE)) ) | |||
| 241 | return -EFAULT14; | |||
| 242 | pusBuffer = (unsigned short __user *) (rWriteData.pBuf); | |||
| 243 | ||||
| 244 | PRINTK_4(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); } | |||
| 245 | "mwavedd::mwave_ioctl IOCTL_MW_WRITE_DATA,"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); } | |||
| 246 | " size %lx, ioarg %lx pusBuffer %p\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); } | |||
| 247 | rWriteData.ulDataLength, ioarg,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); } | |||
| 248 | pusBuffer)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_DATA," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); }; | |||
| 249 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 250 | retval = tp3780I_ReadWriteDspDStore(&pDrvData->rBDData, | |||
| 251 | iocmd, pusBuffer, | |||
| 252 | rWriteData.ulDataLength, | |||
| 253 | rWriteData.usDspAddress); | |||
| 254 | mutex_unlock(&mwave_mutex); | |||
| 255 | } | |||
| 256 | break; | |||
| 257 | ||||
| 258 | case IOCTL_MW_WRITE_INST(((1U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((8)) << 0) | (((((sizeof(MW_READWRITE) == sizeof(MW_READWRITE [1]) && sizeof(MW_READWRITE) < (1 << 14)) ? sizeof (MW_READWRITE) : __invalid_size_argument_for_IOC))) << ( (0 +8)+8))): { | |||
| 259 | MW_READWRITE rWriteData; | |||
| 260 | unsigned short __user *pusBuffer = NULL((void *)0); | |||
| 261 | ||||
| 262 | if( copy_from_user(&rWriteData, arg, | |||
| 263 | sizeof(MW_READWRITE)) ) | |||
| 264 | return -EFAULT14; | |||
| 265 | pusBuffer = (unsigned short __user *)(rWriteData.pBuf); | |||
| 266 | ||||
| 267 | PRINTK_4(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_INST," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); } | |||
| 268 | "mwavedd::mwave_ioctl IOCTL_MW_WRITE_INST,"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_INST," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); } | |||
| 269 | " size %lx, ioarg %lx pusBuffer %p\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_INST," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); } | |||
| 270 | rWriteData.ulDataLength, ioarg,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_INST," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); } | |||
| 271 | pusBuffer)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_WRITE_INST," " size %lx, ioarg %lx pusBuffer %p\n",rWriteData.ulDataLength ,ioarg,pusBuffer); }; | |||
| 272 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 273 | retval = tp3780I_ReadWriteDspIStore(&pDrvData->rBDData, | |||
| 274 | iocmd, pusBuffer, | |||
| 275 | rWriteData.ulDataLength, | |||
| 276 | rWriteData.usDspAddress); | |||
| 277 | mutex_unlock(&mwave_mutex); | |||
| 278 | } | |||
| 279 | break; | |||
| 280 | ||||
| 281 | case IOCTL_MW_REGISTER_IPC(((1U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((9)) << 0) | (((((sizeof(int) == sizeof(int[1]) && sizeof(int) < (1 << 14)) ? sizeof(int) : __invalid_size_argument_for_IOC ))) << ((0 +8)+8))): { | |||
| 282 | unsigned int ipcnum = (unsigned int) ioarg; | |||
| 283 | ||||
| 284 | if (ipcnum >= ARRAY_SIZE(pDrvData->IPCs)(sizeof(pDrvData->IPCs) / sizeof((pDrvData->IPCs)[0]) + (sizeof(struct { int:-!!(__builtin_types_compatible_p(typeof ((pDrvData->IPCs)), typeof(&(pDrvData->IPCs)[0]))); })))) { | |||
| 285 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 286 | "mwavedd::mwave_ioctl:" | |||
| 287 | " IOCTL_MW_REGISTER_IPC:" | |||
| 288 | " Error: Invalid ipcnum %x\n", | |||
| 289 | ipcnum); | |||
| 290 | return -EINVAL22; | |||
| 291 | } | |||
| 292 | PRINTK_3(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x entry usIntCount %x\n",ipcnum,pDrvData->IPCs[ ipcnum].usIntCount); } | |||
| 293 | "mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x entry usIntCount %x\n",ipcnum,pDrvData->IPCs[ ipcnum].usIntCount); } | |||
| 294 | " ipcnum %x entry usIntCount %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x entry usIntCount %x\n",ipcnum,pDrvData->IPCs[ ipcnum].usIntCount); } | |||
| 295 | ipcnum,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x entry usIntCount %x\n",ipcnum,pDrvData->IPCs[ ipcnum].usIntCount); } | |||
| 296 | pDrvData->IPCs[ipcnum].usIntCount)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x entry usIntCount %x\n",ipcnum,pDrvData->IPCs[ ipcnum].usIntCount); }; | |||
| 297 | ||||
| 298 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 299 | pDrvData->IPCs[ipcnum].bIsHere = false; | |||
| 300 | pDrvData->IPCs[ipcnum].bIsEnabled = true; | |||
| 301 | mutex_unlock(&mwave_mutex); | |||
| 302 | ||||
| 303 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x exit\n",ipcnum); } | |||
| 304 | "mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x exit\n",ipcnum); } | |||
| 305 | " ipcnum %x exit\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x exit\n",ipcnum); } | |||
| 306 | ipcnum)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_REGISTER_IPC" " ipcnum %x exit\n",ipcnum); }; | |||
| 307 | } | |||
| 308 | break; | |||
| 309 | ||||
| 310 | case IOCTL_MW_GET_IPC(((1U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((11)) << 0) | (((((sizeof(int) == sizeof(int[1]) && sizeof(int) < (1 << 14)) ? sizeof(int) : __invalid_size_argument_for_IOC ))) << ((0 +8)+8))): { | |||
| 311 | unsigned int ipcnum = (unsigned int) ioarg; | |||
| 312 | ||||
| 313 | if (ipcnum >= ARRAY_SIZE(pDrvData->IPCs)(sizeof(pDrvData->IPCs) / sizeof((pDrvData->IPCs)[0]) + (sizeof(struct { int:-!!(__builtin_types_compatible_p(typeof ((pDrvData->IPCs)), typeof(&(pDrvData->IPCs)[0]))); })))) { | |||
| 314 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 315 | "mwavedd::mwave_ioctl:" | |||
| 316 | " IOCTL_MW_GET_IPC: Error:" | |||
| 317 | " Invalid ipcnum %x\n", ipcnum); | |||
| 318 | return -EINVAL22; | |||
| 319 | } | |||
| 320 | PRINTK_3(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC" " ipcnum %x, usIntCount %x\n",ipcnum,pDrvData->IPCs[ipcnum ].usIntCount); } | |||
| 321 | "mwavedd::mwave_ioctl IOCTL_MW_GET_IPC"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC" " ipcnum %x, usIntCount %x\n",ipcnum,pDrvData->IPCs[ipcnum ].usIntCount); } | |||
| 322 | " ipcnum %x, usIntCount %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC" " ipcnum %x, usIntCount %x\n",ipcnum,pDrvData->IPCs[ipcnum ].usIntCount); } | |||
| 323 | ipcnum,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC" " ipcnum %x, usIntCount %x\n",ipcnum,pDrvData->IPCs[ipcnum ].usIntCount); } | |||
| 324 | pDrvData->IPCs[ipcnum].usIntCount)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC" " ipcnum %x, usIntCount %x\n",ipcnum,pDrvData->IPCs[ipcnum ].usIntCount); }; | |||
| 325 | ||||
| 326 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 327 | if (pDrvData->IPCs[ipcnum].bIsEnabled == true) { | |||
| 328 | DECLARE_WAITQUEUE(wait, current)wait_queue_t wait = { .private = get_current(), .func = default_wake_function , .task_list = { ((void *)0), ((void *)0) } }; | |||
| 329 | ||||
| 330 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, thread for" " ipc %x going to sleep\n",ipcnum); } | |||
| 331 | "mwavedd::mwave_ioctl, thread for"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, thread for" " ipc %x going to sleep\n",ipcnum); } | |||
| 332 | " ipc %x going to sleep\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, thread for" " ipc %x going to sleep\n",ipcnum); } | |||
| 333 | ipcnum)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, thread for" " ipc %x going to sleep\n",ipcnum); }; | |||
| 334 | add_wait_queue(&pDrvData->IPCs[ipcnum].ipc_wait_queue, &wait); | |||
| 335 | pDrvData->IPCs[ipcnum].bIsHere = true; | |||
| 336 | set_current_state(TASK_INTERRUPTIBLE)do { get_current()->task_state_change = ({ __label__ __here ; __here: (unsigned long)&&__here; }); do { (void)({ __typeof__ (*((&get_current()->state))) __ret = (((1))); switch ( sizeof(*((&get_current()->state)))) { case 1: asm volatile ("" "xchg" "b %b0, %1\n" : "+q" (__ret), "+m" (*((&get_current ()->state))) : : "memory", "cc"); break; case 2: asm volatile ("" "xchg" "w %w0, %1\n" : "+r" (__ret), "+m" (*((&get_current ()->state))) : : "memory", "cc"); break; case 4: asm volatile ("" "xchg" "l %0, %1\n" : "+r" (__ret), "+m" (*((&get_current ()->state))) : : "memory", "cc"); break; case 8: asm volatile ("" "xchg" "q %q0, %1\n" : "+r" (__ret), "+m" (*((&get_current ()->state))) : : "memory", "cc"); break; default: __xchg_wrong_size (); } __ret; }); } while (0); } while (0); | |||
| 337 | /* check whether an event was signalled by */ | |||
| 338 | /* the interrupt handler while we were gone */ | |||
| 339 | if (pDrvData->IPCs[ipcnum].usIntCount == 1) { /* first int has occurred (race condition) */ | |||
| 340 | pDrvData->IPCs[ipcnum].usIntCount = 2; /* first int has been handled */ | |||
| 341 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " handling first int\n",ipcnum ); } | |||
| 342 | "mwavedd::mwave_ioctl"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " handling first int\n",ipcnum ); } | |||
| 343 | " IOCTL_MW_GET_IPC ipcnum %x"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " handling first int\n",ipcnum ); } | |||
| 344 | " handling first int\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " handling first int\n",ipcnum ); } | |||
| 345 | ipcnum)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " handling first int\n",ipcnum ); }; | |||
| 346 | } else { /* either 1st int has not yet occurred, or we have already handled the first int */ | |||
| 347 | schedule(); | |||
| 348 | if (pDrvData->IPCs[ipcnum].usIntCount == 1) { | |||
| 349 | pDrvData->IPCs[ipcnum].usIntCount = 2; | |||
| 350 | } | |||
| 351 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " woke up and returning to" " application\n" ,ipcnum); } | |||
| 352 | "mwavedd::mwave_ioctl"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " woke up and returning to" " application\n" ,ipcnum); } | |||
| 353 | " IOCTL_MW_GET_IPC ipcnum %x"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " woke up and returning to" " application\n" ,ipcnum); } | |||
| 354 | " woke up and returning to"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " woke up and returning to" " application\n" ,ipcnum); } | |||
| 355 | " application\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " woke up and returning to" " application\n" ,ipcnum); } | |||
| 356 | ipcnum)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl" " IOCTL_MW_GET_IPC ipcnum %x" " woke up and returning to" " application\n" ,ipcnum); }; | |||
| 357 | } | |||
| 358 | pDrvData->IPCs[ipcnum].bIsHere = false; | |||
| 359 | remove_wait_queue(&pDrvData->IPCs[ipcnum].ipc_wait_queue, &wait); | |||
| 360 | set_current_state(TASK_RUNNING)do { get_current()->task_state_change = ({ __label__ __here ; __here: (unsigned long)&&__here; }); do { (void)({ __typeof__ (*((&get_current()->state))) __ret = (((0))); switch ( sizeof(*((&get_current()->state)))) { case 1: asm volatile ("" "xchg" "b %b0, %1\n" : "+q" (__ret), "+m" (*((&get_current ()->state))) : : "memory", "cc"); break; case 2: asm volatile ("" "xchg" "w %w0, %1\n" : "+r" (__ret), "+m" (*((&get_current ()->state))) : : "memory", "cc"); break; case 4: asm volatile ("" "xchg" "l %0, %1\n" : "+r" (__ret), "+m" (*((&get_current ()->state))) : : "memory", "cc"); break; case 8: asm volatile ("" "xchg" "q %q0, %1\n" : "+r" (__ret), "+m" (*((&get_current ()->state))) : : "memory", "cc"); break; default: __xchg_wrong_size (); } __ret; }); } while (0); } while (0); | |||
| 361 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC," " returning thread for ipc %x" " processing\n",ipcnum); } | |||
| 362 | "mwavedd::mwave_ioctl IOCTL_MW_GET_IPC,"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC," " returning thread for ipc %x" " processing\n",ipcnum); } | |||
| 363 | " returning thread for ipc %x"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC," " returning thread for ipc %x" " processing\n",ipcnum); } | |||
| 364 | " processing\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC," " returning thread for ipc %x" " processing\n",ipcnum); } | |||
| 365 | ipcnum)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_GET_IPC," " returning thread for ipc %x" " processing\n",ipcnum); }; | |||
| 366 | } | |||
| 367 | mutex_unlock(&mwave_mutex); | |||
| 368 | } | |||
| 369 | break; | |||
| 370 | ||||
| 371 | case IOCTL_MW_UNREGISTER_IPC(((1U) << (((0 +8)+8)+14)) | (((219)) << (0 +8)) | (((10)) << 0) | (((((sizeof(int) == sizeof(int[1]) && sizeof(int) < (1 << 14)) ? sizeof(int) : __invalid_size_argument_for_IOC ))) << ((0 +8)+8))): { | |||
| 372 | unsigned int ipcnum = (unsigned int) ioarg; | |||
| 373 | ||||
| 374 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_UNREGISTER_IPC" " ipcnum %x\n",ipcnum); } | |||
| 375 | "mwavedd::mwave_ioctl IOCTL_MW_UNREGISTER_IPC"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_UNREGISTER_IPC" " ipcnum %x\n",ipcnum); } | |||
| 376 | " ipcnum %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_UNREGISTER_IPC" " ipcnum %x\n",ipcnum); } | |||
| 377 | ipcnum)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl IOCTL_MW_UNREGISTER_IPC" " ipcnum %x\n",ipcnum); }; | |||
| 378 | if (ipcnum >= ARRAY_SIZE(pDrvData->IPCs)(sizeof(pDrvData->IPCs) / sizeof((pDrvData->IPCs)[0]) + (sizeof(struct { int:-!!(__builtin_types_compatible_p(typeof ((pDrvData->IPCs)), typeof(&(pDrvData->IPCs)[0]))); })))) { | |||
| 379 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 380 | "mwavedd::mwave_ioctl:" | |||
| 381 | " IOCTL_MW_UNREGISTER_IPC:" | |||
| 382 | " Error: Invalid ipcnum %x\n", | |||
| 383 | ipcnum); | |||
| 384 | return -EINVAL22; | |||
| 385 | } | |||
| 386 | mutex_lock(&mwave_mutex)mutex_lock_nested(&mwave_mutex, 0); | |||
| 387 | if (pDrvData->IPCs[ipcnum].bIsEnabled == true) { | |||
| 388 | pDrvData->IPCs[ipcnum].bIsEnabled = false; | |||
| 389 | if (pDrvData->IPCs[ipcnum].bIsHere == true) { | |||
| 390 | wake_up_interruptible(&pDrvData->IPCs[ipcnum].ipc_wait_queue)__wake_up(&pDrvData->IPCs[ipcnum].ipc_wait_queue, 1, 1 , ((void *)0)); | |||
| 391 | } | |||
| 392 | } | |||
| 393 | mutex_unlock(&mwave_mutex); | |||
| 394 | } | |||
| 395 | break; | |||
| 396 | ||||
| 397 | default: | |||
| 398 | return -ENOTTY25; | |||
| 399 | break; | |||
| 400 | } /* switch */ | |||
| 401 | ||||
| 402 | PRINTK_2(TRACE_MWAVE, "mwavedd::mwave_ioctl, exit retval %x\n", retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_ioctl, exit retval %x\n" ,retval); }; | |||
| 403 | ||||
| 404 | return retval; | |||
| 405 | } | |||
| 406 | ||||
| 407 | ||||
| 408 | static ssize_t mwave_read(struct file *file, char __user *buf, size_t count, | |||
| 409 | loff_t * ppos) | |||
| 410 | { | |||
| 411 | PRINTK_5(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_read entry file %p, buf %p, count %zx ppos %p\n" ,file,buf,count,ppos); } | |||
| 412 | "mwavedd::mwave_read entry file %p, buf %p, count %zx ppos %p\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_read entry file %p, buf %p, count %zx ppos %p\n" ,file,buf,count,ppos); } | |||
| 413 | file, buf, count, ppos)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_read entry file %p, buf %p, count %zx ppos %p\n" ,file,buf,count,ppos); }; | |||
| 414 | ||||
| 415 | return -EINVAL22; | |||
| 416 | } | |||
| 417 | ||||
| 418 | ||||
| 419 | static ssize_t mwave_write(struct file *file, const char __user *buf, | |||
| 420 | size_t count, loff_t * ppos) | |||
| 421 | { | |||
| 422 | PRINTK_5(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_write entry file %p, buf %p," " count %zx ppos %p\n",file,buf,count,ppos); } | |||
| 423 | "mwavedd::mwave_write entry file %p, buf %p,"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_write entry file %p, buf %p," " count %zx ppos %p\n",file,buf,count,ppos); } | |||
| 424 | " count %zx ppos %p\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_write entry file %p, buf %p," " count %zx ppos %p\n",file,buf,count,ppos); } | |||
| 425 | file, buf, count, ppos)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_write entry file %p, buf %p," " count %zx ppos %p\n",file,buf,count,ppos); }; | |||
| 426 | ||||
| 427 | return -EINVAL22; | |||
| 428 | } | |||
| 429 | ||||
| 430 | ||||
| 431 | static int register_serial_portandirq(unsigned int port, int irq) | |||
| 432 | { | |||
| 433 | struct uart_8250_port uart; | |||
| 434 | ||||
| 435 | switch ( port ) { | |||
| 436 | case 0x3f8: | |||
| 437 | case 0x2f8: | |||
| 438 | case 0x3e8: | |||
| 439 | case 0x2e8: | |||
| 440 | /* OK */ | |||
| 441 | break; | |||
| 442 | default: | |||
| 443 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 444 | "mwavedd::register_serial_portandirq:" | |||
| 445 | " Error: Illegal port %x\n", port ); | |||
| 446 | return -1; | |||
| 447 | } /* switch */ | |||
| 448 | /* port is okay */ | |||
| 449 | ||||
| 450 | switch ( irq ) { | |||
| 451 | case 3: | |||
| 452 | case 4: | |||
| 453 | case 5: | |||
| 454 | case 7: | |||
| 455 | /* OK */ | |||
| 456 | break; | |||
| 457 | default: | |||
| 458 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 459 | "mwavedd::register_serial_portandirq:" | |||
| 460 | " Error: Illegal irq %x\n", irq ); | |||
| 461 | return -1; | |||
| 462 | } /* switch */ | |||
| 463 | /* irq is okay */ | |||
| 464 | ||||
| 465 | memset(&uart, 0, sizeof(uart)); | |||
| 466 | ||||
| 467 | uart.port.uartclk = 1843200; | |||
| 468 | uart.port.iobase = port; | |||
| 469 | uart.port.irq = irq; | |||
| 470 | uart.port.iotype = UPIO_PORT(0); | |||
| 471 | uart.port.flags = UPF_SHARE_IRQ(( upf_t) (1 << 24)); | |||
| 472 | return serial8250_register_8250_port(&uart); | |||
| 473 | } | |||
| 474 | ||||
| 475 | ||||
| 476 | static const struct file_operations mwave_fops = { | |||
| 477 | .owner = THIS_MODULE((struct module *)0), | |||
| 478 | .read = mwave_read, | |||
| 479 | .write = mwave_write, | |||
| 480 | .unlocked_ioctl = mwave_ioctl, | |||
| 481 | .open = mwave_open, | |||
| 482 | .release = mwave_close, | |||
| 483 | .llseek = default_llseek, | |||
| 484 | }; | |||
| 485 | ||||
| 486 | ||||
| 487 | static struct miscdevice mwave_misc_dev = { MWAVE_MINOR219, "mwave", &mwave_fops }; | |||
| 488 | ||||
| 489 | #if 0 /* totally b0rked */ | |||
| 490 | /* | |||
| 491 | * sysfs support <[email protected]> | |||
| 492 | */ | |||
| 493 | ||||
| 494 | struct device mwave_device; | |||
| 495 | ||||
| 496 | /* Prevent code redundancy, create a macro for mwave_show_* functions. */ | |||
| 497 | #define mwave_show_function(attr_name, format_string, field) \ | |||
| 498 | static ssize_t mwave_show_##attr_name(struct device *dev, struct device_attribute *attr, char *buf) \ | |||
| 499 | { \ | |||
| 500 | DSP_3780I_CONFIG_SETTINGS *pSettings = \ | |||
| 501 | &mwave_s_mdd.rBDData.rDspSettings; \ | |||
| 502 | return sprintf(buf, format_string, pSettings->field); \ | |||
| 503 | } | |||
| 504 | ||||
| 505 | /* All of our attributes are read attributes. */ | |||
| 506 | #define mwave_dev_rd_attr(attr_name, format_string, field) \ | |||
| 507 | mwave_show_function(attr_name, format_string, field) \ | |||
| 508 | static DEVICE_ATTR(attr_name, S_IRUGO, mwave_show_##attr_name, NULL)struct device_attribute dev_attr_attr_name = { .attr = {.name = "attr_name", .mode = ((sizeof(struct { int:-!!(((00400|00040 |00004)) < 0); })) + (sizeof(struct { int:-!!(((00400|00040 |00004)) > 0777); })) + (sizeof(struct { int:-!!(((((00400 |00040|00004)) >> 6) & 4) < ((((00400|00040|00004 )) >> 3) & 4)); })) + (sizeof(struct { int:-!!((((( 00400|00040|00004)) >> 3) & 4) < (((00400|00040| 00004)) & 4)); })) + (sizeof(struct { int:-!!(((((00400|00040 |00004)) >> 6) & 2) < ((((00400|00040|00004)) >> 3) & 2)); })) + (sizeof(struct { int:-!!(((00400|00040|00004 )) & 2); })) + ((00400|00040|00004))) }, .show = mwave_show_ ##attr_name, .store = ((void *)0), } | |||
| 509 | ||||
| 510 | mwave_dev_rd_attr (3780i_dma, "%i\n", usDspDma); | |||
| 511 | mwave_dev_rd_attr (3780i_irq, "%i\n", usDspIrq); | |||
| 512 | mwave_dev_rd_attr (3780i_io, "%#.4x\n", usDspBaseIO); | |||
| 513 | mwave_dev_rd_attr (uart_irq, "%i\n", usUartIrq); | |||
| 514 | mwave_dev_rd_attr (uart_io, "%#.4x\n", usUartBaseIO); | |||
| 515 | ||||
| 516 | static struct device_attribute * const mwave_dev_attrs[] = { | |||
| 517 | &dev_attr_3780i_dma, | |||
| 518 | &dev_attr_3780i_irq, | |||
| 519 | &dev_attr_3780i_io, | |||
| 520 | &dev_attr_uart_irq, | |||
| 521 | &dev_attr_uart_io, | |||
| 522 | }; | |||
| 523 | #endif | |||
| 524 | ||||
| 525 | /* | |||
| 526 | * mwave_init is called on module load | |||
| 527 | * | |||
| 528 | * mwave_exit is called on module unload | |||
| 529 | * mwave_exit is also used to clean up after an aborted mwave_init | |||
| 530 | */ | |||
| 531 | static void mwave_exit(void) | |||
| 532 | { | |||
| 533 | pMWAVE_DEVICE_DATA pDrvData = &mwave_s_mdd; | |||
| 534 | ||||
| 535 | PRINTK_1(TRACE_MWAVE, "mwavedd::mwave_exit entry\n")if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_exit entry\n" ); }; | |||
| 536 | ||||
| 537 | #if 0 | |||
| 538 | for (i = 0; i < pDrvData->nr_registered_attrs; i++) | |||
| 539 | device_remove_file(&mwave_device, mwave_dev_attrs[i]); | |||
| 540 | pDrvData->nr_registered_attrs = 0; | |||
| 541 | ||||
| 542 | if (pDrvData->device_registered) { | |||
| 543 | device_unregister(&mwave_device); | |||
| 544 | pDrvData->device_registered = false; | |||
| 545 | } | |||
| 546 | #endif | |||
| 547 | ||||
| 548 | if ( pDrvData->sLine >= 0 ) { | |||
| 549 | serial8250_unregister_port(pDrvData->sLine); | |||
| 550 | } | |||
| 551 | if (pDrvData->bMwaveDevRegistered) { | |||
| 552 | misc_deregister(&mwave_misc_dev); | |||
| 553 | } | |||
| 554 | if (pDrvData->bDSPEnabled) { | |||
| 555 | tp3780I_DisableDSP(&pDrvData->rBDData); | |||
| 556 | } | |||
| 557 | if (pDrvData->bResourcesClaimed) { | |||
| 558 | tp3780I_ReleaseResources(&pDrvData->rBDData); | |||
| 559 | } | |||
| 560 | if (pDrvData->bBDInitialized) { | |||
| 561 | tp3780I_Cleanup(&pDrvData->rBDData); | |||
| 562 | } | |||
| 563 | ||||
| 564 | PRINTK_1(TRACE_MWAVE, "mwavedd::mwave_exit exit\n")if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_exit exit\n" ); }; | |||
| 565 | } | |||
| 566 | ||||
| 567 | module_exit(mwave_exit)static exitcall_t __exitcall_mwave_exit __attribute__((__used__ )) __attribute__ ((__section__(".exitcall.exit"))) = mwave_exit ;; | |||
| 568 | ||||
| 569 | static int __init__attribute__ ((__section__(".init.text"))) __attribute__((no_instrument_function )) mwave_init(void) | |||
| 570 | { | |||
| 571 | int i; | |||
| 572 | int retval = 0; | |||
| 573 | pMWAVE_DEVICE_DATA pDrvData = &mwave_s_mdd; | |||
| 574 | ||||
| 575 | PRINTK_1(TRACE_MWAVE, "mwavedd::mwave_init entry\n")if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init entry\n" ); }; | |||
| 576 | ||||
| 577 | memset(&mwave_s_mdd, 0, sizeof(MWAVE_DEVICE_DATA)); | |||
| 578 | ||||
| 579 | pDrvData->bBDInitialized = false; | |||
| 580 | pDrvData->bResourcesClaimed = false; | |||
| 581 | pDrvData->bDSPEnabled = false; | |||
| 582 | pDrvData->bDSPReset = false; | |||
| 583 | pDrvData->bMwaveDevRegistered = false; | |||
| 584 | pDrvData->sLine = -1; | |||
| 585 | ||||
| 586 | for (i = 0; i < ARRAY_SIZE(pDrvData->IPCs)(sizeof(pDrvData->IPCs) / sizeof((pDrvData->IPCs)[0]) + (sizeof(struct { int:-!!(__builtin_types_compatible_p(typeof ((pDrvData->IPCs)), typeof(&(pDrvData->IPCs)[0]))); }))); i++) { | |||
| 587 | pDrvData->IPCs[i].bIsEnabled = false; | |||
| 588 | pDrvData->IPCs[i].bIsHere = false; | |||
| 589 | pDrvData->IPCs[i].usIntCount = 0; /* no ints received yet */ | |||
| 590 | init_waitqueue_head(&pDrvData->IPCs[i].ipc_wait_queue)do { static struct lock_class_key __key; __init_waitqueue_head ((&pDrvData->IPCs[i].ipc_wait_queue), "&pDrvData->IPCs[i].ipc_wait_queue" , &__key); } while (0); | |||
| 591 | } | |||
| 592 | ||||
| 593 | retval = tp3780I_InitializeBoardData(&pDrvData->rBDData); | |||
| 594 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_InitializeBoardData" " retval %x\n",retval); } | |||
| 595 | "mwavedd::mwave_init, return from tp3780I_InitializeBoardData"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_InitializeBoardData" " retval %x\n",retval); } | |||
| 596 | " retval %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_InitializeBoardData" " retval %x\n",retval); } | |||
| 597 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_InitializeBoardData" " retval %x\n",retval); }; | |||
| 598 | if (retval) { | |||
| 599 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 600 | "mwavedd::mwave_init: Error:" | |||
| 601 | " Failed to initialize board data\n"); | |||
| 602 | goto cleanup_error; | |||
| 603 | } | |||
| 604 | pDrvData->bBDInitialized = true; | |||
| 605 | ||||
| 606 | retval = tp3780I_CalcResources(&pDrvData->rBDData); | |||
| 607 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_CalcResources" " retval %x\n",retval); } | |||
| 608 | "mwavedd::mwave_init, return from tp3780I_CalcResources"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_CalcResources" " retval %x\n",retval); } | |||
| 609 | " retval %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_CalcResources" " retval %x\n",retval); } | |||
| 610 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_CalcResources" " retval %x\n",retval); }; | |||
| 611 | if (retval) { | |||
| 612 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 613 | "mwavedd:mwave_init: Error:" | |||
| 614 | " Failed to calculate resources\n"); | |||
| 615 | goto cleanup_error; | |||
| 616 | } | |||
| 617 | ||||
| 618 | retval = tp3780I_ClaimResources(&pDrvData->rBDData); | |||
| 619 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_ClaimResources" " retval %x\n",retval); } | |||
| 620 | "mwavedd::mwave_init, return from tp3780I_ClaimResources"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_ClaimResources" " retval %x\n",retval); } | |||
| 621 | " retval %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_ClaimResources" " retval %x\n",retval); } | |||
| 622 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_ClaimResources" " retval %x\n",retval); }; | |||
| 623 | if (retval) { | |||
| 624 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 625 | "mwavedd:mwave_init: Error:" | |||
| 626 | " Failed to claim resources\n"); | |||
| 627 | goto cleanup_error; | |||
| 628 | } | |||
| 629 | pDrvData->bResourcesClaimed = true; | |||
| 630 | ||||
| 631 | retval = tp3780I_EnableDSP(&pDrvData->rBDData); | |||
| 632 | PRINTK_2(TRACE_MWAVE,if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_EnableDSP" " retval %x\n",retval); } | |||
| 633 | "mwavedd::mwave_init, return from tp3780I_EnableDSP"if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_EnableDSP" " retval %x\n",retval); } | |||
| 634 | " retval %x\n",if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_EnableDSP" " retval %x\n",retval); } | |||
| 635 | retval)if (0x0001 & (mwave_debug)) { printk("mwavedd::mwave_init, return from tp3780I_EnableDSP" " retval %x\n",retval); }; | |||
| 636 | if (retval) { | |||
| 637 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 638 | "mwavedd:mwave_init: Error:" | |||
| 639 | " Failed to enable DSP\n"); | |||
| 640 | goto cleanup_error; | |||
| 641 | } | |||
| 642 | pDrvData->bDSPEnabled = true; | |||
| 643 | ||||
| 644 | if (misc_register(&mwave_misc_dev) < 0) { | |||
| 645 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 646 | "mwavedd:mwave_init: Error:" | |||
| 647 | " Failed to register misc device\n"); | |||
| 648 | goto cleanup_error; | |||
| 649 | } | |||
| 650 | pDrvData->bMwaveDevRegistered = true; | |||
| 651 | ||||
| 652 | pDrvData->sLine = register_serial_portandirq( | |||
| 653 | pDrvData->rBDData.rDspSettings.usUartBaseIO, | |||
| 654 | pDrvData->rBDData.rDspSettings.usUartIrq | |||
| 655 | ); | |||
| 656 | if (pDrvData->sLine < 0) { | |||
| 657 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 658 | "mwavedd:mwave_init: Error:" | |||
| 659 | " Failed to register serial driver\n"); | |||
| 660 | goto cleanup_error; | |||
| 661 | } | |||
| 662 | /* uart is registered */ | |||
| 663 | ||||
| 664 | #if 0 | |||
| 665 | /* sysfs */ | |||
| 666 | memset(&mwave_device, 0, sizeof (struct device)); | |||
| 667 | dev_set_name(&mwave_device, "mwave"); | |||
| 668 | ||||
| 669 | if (device_register(&mwave_device)) | |||
| 670 | goto cleanup_error; | |||
| 671 | pDrvData->device_registered = true; | |||
| 672 | for (i = 0; i < ARRAY_SIZE(mwave_dev_attrs)(sizeof(mwave_dev_attrs) / sizeof((mwave_dev_attrs)[0]) + (sizeof (struct { int:-!!(__builtin_types_compatible_p(typeof((mwave_dev_attrs )), typeof(&(mwave_dev_attrs)[0]))); }))); i++) { | |||
| 673 | if(device_create_file(&mwave_device, mwave_dev_attrs[i])) { | |||
| 674 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 675 | "mwavedd:mwave_init: Error:" | |||
| 676 | " Failed to create sysfs file %s\n", | |||
| 677 | mwave_dev_attrs[i]->attr.name); | |||
| 678 | goto cleanup_error; | |||
| 679 | } | |||
| 680 | pDrvData->nr_registered_attrs++; | |||
| 681 | } | |||
| 682 | #endif | |||
| 683 | ||||
| 684 | /* SUCCESS! */ | |||
| 685 | return 0; | |||
| 686 | ||||
| 687 | cleanup_error: | |||
| 688 | PRINTK_ERRORprintk(KERN_ERR_MWAVE"\001" "3" "mwave: " | |||
| 689 | "mwavedd::mwave_init: Error:" | |||
| 690 | " Failed to initialize\n"); | |||
| 691 | mwave_exit(); /* clean up */ | |||
| 692 | ||||
| 693 | return -EIO5; | |||
| 694 | } | |||
| 695 | ||||
| 696 | module_init(mwave_init)static initcall_t __initcall_mwave_init6 __attribute__((__used__ )) __attribute__((__section__(".initcall" "6" ".init"))) = mwave_init ;;; | |||
| 697 |