aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/char/stallion.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/char/stallion.c')
-rw-r--r--drivers/char/stallion.c67
1 files changed, 31 insertions, 36 deletions
diff --git a/drivers/char/stallion.c b/drivers/char/stallion.c
index 2db2e9fbb5c6..97c7dc9c0cf0 100644
--- a/drivers/char/stallion.c
+++ b/drivers/char/stallion.c
@@ -63,7 +63,7 @@
63#define BRD_EASYIOPCI 28 63#define BRD_EASYIOPCI 28
64 64
65struct stlconf { 65struct stlconf {
66 int brdtype; 66 unsigned int brdtype;
67 int ioaddr1; 67 int ioaddr1;
68 int ioaddr2; 68 int ioaddr2;
69 unsigned long memaddr; 69 unsigned long memaddr;
@@ -121,15 +121,6 @@ static struct ktermios stl_deftermios = {
121}; 121};
122 122
123/* 123/*
124 * Define global stats structures. Not used often, and can be
125 * re-used for each stats call.
126 */
127static comstats_t stl_comstats;
128static combrd_t stl_brdstats;
129static struct stlbrd stl_dummybrd;
130static struct stlport stl_dummyport;
131
132/*
133 * Define global place to put buffer overflow characters. 124 * Define global place to put buffer overflow characters.
134 */ 125 */
135static char stl_unwanted[SC26198_RXFIFOSIZE]; 126static char stl_unwanted[SC26198_RXFIFOSIZE];
@@ -200,7 +191,7 @@ static char *stl_brdnames[] = {
200 * load line. These allow for easy board definitions, and easy 191 * load line. These allow for easy board definitions, and easy
201 * modification of the io, memory and irq resoucres. 192 * modification of the io, memory and irq resoucres.
202 */ 193 */
203static int stl_nargs = 0; 194static unsigned int stl_nargs;
204static char *board0[4]; 195static char *board0[4];
205static char *board1[4]; 196static char *board1[4];
206static char *board2[4]; 197static char *board2[4];
@@ -632,7 +623,7 @@ static struct class *stallion_class;
632static int __init stl_parsebrd(struct stlconf *confp, char **argp) 623static int __init stl_parsebrd(struct stlconf *confp, char **argp)
633{ 624{
634 char *sp; 625 char *sp;
635 int i; 626 unsigned int i;
636 627
637 pr_debug("stl_parsebrd(confp=%p,argp=%p)\n", confp, argp); 628 pr_debug("stl_parsebrd(confp=%p,argp=%p)\n", confp, argp);
638 629
@@ -694,8 +685,8 @@ static int stl_open(struct tty_struct *tty, struct file *filp)
694{ 685{
695 struct stlport *portp; 686 struct stlport *portp;
696 struct stlbrd *brdp; 687 struct stlbrd *brdp;
697 unsigned int minordev; 688 unsigned int minordev, brdnr, panelnr;
698 int brdnr, panelnr, portnr, rc; 689 int portnr, rc;
699 690
700 pr_debug("stl_open(tty=%p,filp=%p): device=%s\n", tty, filp, tty->name); 691 pr_debug("stl_open(tty=%p,filp=%p): device=%s\n", tty, filp, tty->name);
701 692
@@ -1556,8 +1547,8 @@ static int stl_readproc(char *page, char **start, off_t off, int count, int *eof
1556 struct stlbrd *brdp; 1547 struct stlbrd *brdp;
1557 struct stlpanel *panelp; 1548 struct stlpanel *panelp;
1558 struct stlport *portp; 1549 struct stlport *portp;
1559 int brdnr, panelnr, portnr, totalport; 1550 unsigned int brdnr, panelnr, portnr;
1560 int curoff, maxoff; 1551 int totalport, curoff, maxoff;
1561 char *pos; 1552 char *pos;
1562 1553
1563 pr_debug("stl_readproc(page=%p,start=%p,off=%lx,count=%d,eof=%p," 1554 pr_debug("stl_readproc(page=%p,start=%p,off=%lx,count=%d,eof=%p,"
@@ -1675,8 +1666,7 @@ static int stl_eiointr(struct stlbrd *brdp)
1675static int stl_echatintr(struct stlbrd *brdp) 1666static int stl_echatintr(struct stlbrd *brdp)
1676{ 1667{
1677 struct stlpanel *panelp; 1668 struct stlpanel *panelp;
1678 unsigned int ioaddr; 1669 unsigned int ioaddr, bnknr;
1679 int bnknr;
1680 int handled = 0; 1670 int handled = 0;
1681 1671
1682 outb((brdp->ioctrlval | ECH_BRDENABLE), brdp->ioctrl); 1672 outb((brdp->ioctrlval | ECH_BRDENABLE), brdp->ioctrl);
@@ -1706,8 +1696,7 @@ static int stl_echatintr(struct stlbrd *brdp)
1706static int stl_echmcaintr(struct stlbrd *brdp) 1696static int stl_echmcaintr(struct stlbrd *brdp)
1707{ 1697{
1708 struct stlpanel *panelp; 1698 struct stlpanel *panelp;
1709 unsigned int ioaddr; 1699 unsigned int ioaddr, bnknr;
1710 int bnknr;
1711 int handled = 0; 1700 int handled = 0;
1712 1701
1713 while (inb(brdp->iostatus) & ECH_INTRPEND) { 1702 while (inb(brdp->iostatus) & ECH_INTRPEND) {
@@ -1732,8 +1721,7 @@ static int stl_echmcaintr(struct stlbrd *brdp)
1732static int stl_echpciintr(struct stlbrd *brdp) 1721static int stl_echpciintr(struct stlbrd *brdp)
1733{ 1722{
1734 struct stlpanel *panelp; 1723 struct stlpanel *panelp;
1735 unsigned int ioaddr; 1724 unsigned int ioaddr, bnknr, recheck;
1736 int bnknr, recheck;
1737 int handled = 0; 1725 int handled = 0;
1738 1726
1739 while (1) { 1727 while (1) {
@@ -1763,8 +1751,7 @@ static int stl_echpciintr(struct stlbrd *brdp)
1763static int stl_echpci64intr(struct stlbrd *brdp) 1751static int stl_echpci64intr(struct stlbrd *brdp)
1764{ 1752{
1765 struct stlpanel *panelp; 1753 struct stlpanel *panelp;
1766 unsigned int ioaddr; 1754 unsigned int ioaddr, bnknr;
1767 int bnknr;
1768 int handled = 0; 1755 int handled = 0;
1769 1756
1770 while (inb(brdp->ioctrl) & 0x1) { 1757 while (inb(brdp->ioctrl) & 0x1) {
@@ -1826,8 +1813,9 @@ static void stl_offintr(struct work_struct *work)
1826 1813
1827static int __devinit stl_initports(struct stlbrd *brdp, struct stlpanel *panelp) 1814static int __devinit stl_initports(struct stlbrd *brdp, struct stlpanel *panelp)
1828{ 1815{
1829 struct stlport *portp; 1816 struct stlport *portp;
1830 int chipmask, i; 1817 unsigned int i;
1818 int chipmask;
1831 1819
1832 pr_debug("stl_initports(brdp=%p,panelp=%p)\n", brdp, panelp); 1820 pr_debug("stl_initports(brdp=%p,panelp=%p)\n", brdp, panelp);
1833 1821
@@ -2052,8 +2040,8 @@ err:
2052static int __devinit stl_initech(struct stlbrd *brdp) 2040static int __devinit stl_initech(struct stlbrd *brdp)
2053{ 2041{
2054 struct stlpanel *panelp; 2042 struct stlpanel *panelp;
2055 unsigned int status, nxtid, ioaddr, conflict; 2043 unsigned int status, nxtid, ioaddr, conflict, panelnr, banknr, i;
2056 int panelnr, banknr, i, retval; 2044 int retval;
2057 char *name; 2045 char *name;
2058 2046
2059 pr_debug("stl_initech(brdp=%p)\n", brdp); 2047 pr_debug("stl_initech(brdp=%p)\n", brdp);
@@ -2337,7 +2325,7 @@ err:
2337 2325
2338static int __devinit stl_getbrdnr(void) 2326static int __devinit stl_getbrdnr(void)
2339{ 2327{
2340 int i; 2328 unsigned int i;
2341 2329
2342 for (i = 0; i < STL_MAXBRDS; i++) 2330 for (i = 0; i < STL_MAXBRDS; i++)
2343 if (stl_brds[i] == NULL) { 2331 if (stl_brds[i] == NULL) {
@@ -2361,7 +2349,7 @@ static int __devinit stl_pciprobe(struct pci_dev *pdev,
2361{ 2349{
2362 struct stlbrd *brdp; 2350 struct stlbrd *brdp;
2363 unsigned int brdtype = ent->driver_data; 2351 unsigned int brdtype = ent->driver_data;
2364 int retval = -ENODEV; 2352 int brdnr, retval = -ENODEV;
2365 2353
2366 if ((pdev->class >> 8) == PCI_CLASS_STORAGE_IDE) 2354 if ((pdev->class >> 8) == PCI_CLASS_STORAGE_IDE)
2367 goto err; 2355 goto err;
@@ -2378,13 +2366,14 @@ static int __devinit stl_pciprobe(struct pci_dev *pdev,
2378 goto err; 2366 goto err;
2379 } 2367 }
2380 mutex_lock(&stl_brdslock); 2368 mutex_lock(&stl_brdslock);
2381 brdp->brdnr = stl_getbrdnr(); 2369 brdnr = stl_getbrdnr();
2382 if (brdp->brdnr < 0) { 2370 if (brdnr < 0) {
2383 dev_err(&pdev->dev, "too many boards found, " 2371 dev_err(&pdev->dev, "too many boards found, "
2384 "maximum supported %d\n", STL_MAXBRDS); 2372 "maximum supported %d\n", STL_MAXBRDS);
2385 mutex_unlock(&stl_brdslock); 2373 mutex_unlock(&stl_brdslock);
2386 goto err_fr; 2374 goto err_fr;
2387 } 2375 }
2376 brdp->brdnr = (unsigned int)brdnr;
2388 stl_brds[brdp->brdnr] = brdp; 2377 stl_brds[brdp->brdnr] = brdp;
2389 mutex_unlock(&stl_brdslock); 2378 mutex_unlock(&stl_brdslock);
2390 2379
@@ -2460,9 +2449,10 @@ static struct pci_driver stl_pcidriver = {
2460 2449
2461static int stl_getbrdstats(combrd_t __user *bp) 2450static int stl_getbrdstats(combrd_t __user *bp)
2462{ 2451{
2452 combrd_t stl_brdstats;
2463 struct stlbrd *brdp; 2453 struct stlbrd *brdp;
2464 struct stlpanel *panelp; 2454 struct stlpanel *panelp;
2465 int i; 2455 unsigned int i;
2466 2456
2467 if (copy_from_user(&stl_brdstats, bp, sizeof(combrd_t))) 2457 if (copy_from_user(&stl_brdstats, bp, sizeof(combrd_t)))
2468 return -EFAULT; 2458 return -EFAULT;
@@ -2508,12 +2498,12 @@ static struct stlport *stl_getport(int brdnr, int panelnr, int portnr)
2508 brdp = stl_brds[brdnr]; 2498 brdp = stl_brds[brdnr];
2509 if (brdp == NULL) 2499 if (brdp == NULL)
2510 return NULL; 2500 return NULL;
2511 if (panelnr < 0 || panelnr >= brdp->nrpanels) 2501 if (panelnr < 0 || (unsigned int)panelnr >= brdp->nrpanels)
2512 return NULL; 2502 return NULL;
2513 panelp = brdp->panels[panelnr]; 2503 panelp = brdp->panels[panelnr];
2514 if (panelp == NULL) 2504 if (panelp == NULL)
2515 return NULL; 2505 return NULL;
2516 if (portnr < 0 || portnr >= panelp->nrports) 2506 if (portnr < 0 || (unsigned int)portnr >= panelp->nrports)
2517 return NULL; 2507 return NULL;
2518 return panelp->ports[portnr]; 2508 return panelp->ports[portnr];
2519} 2509}
@@ -2528,6 +2518,7 @@ static struct stlport *stl_getport(int brdnr, int panelnr, int portnr)
2528 2518
2529static int stl_getportstats(struct stlport *portp, comstats_t __user *cp) 2519static int stl_getportstats(struct stlport *portp, comstats_t __user *cp)
2530{ 2520{
2521 comstats_t stl_comstats;
2531 unsigned char *head, *tail; 2522 unsigned char *head, *tail;
2532 unsigned long flags; 2523 unsigned long flags;
2533 2524
@@ -2585,6 +2576,8 @@ static int stl_getportstats(struct stlport *portp, comstats_t __user *cp)
2585 2576
2586static int stl_clrportstats(struct stlport *portp, comstats_t __user *cp) 2577static int stl_clrportstats(struct stlport *portp, comstats_t __user *cp)
2587{ 2578{
2579 comstats_t stl_comstats;
2580
2588 if (!portp) { 2581 if (!portp) {
2589 if (copy_from_user(&stl_comstats, cp, sizeof(comstats_t))) 2582 if (copy_from_user(&stl_comstats, cp, sizeof(comstats_t)))
2590 return -EFAULT; 2583 return -EFAULT;
@@ -2610,6 +2603,7 @@ static int stl_clrportstats(struct stlport *portp, comstats_t __user *cp)
2610 2603
2611static int stl_getportstruct(struct stlport __user *arg) 2604static int stl_getportstruct(struct stlport __user *arg)
2612{ 2605{
2606 struct stlport stl_dummyport;
2613 struct stlport *portp; 2607 struct stlport *portp;
2614 2608
2615 if (copy_from_user(&stl_dummyport, arg, sizeof(struct stlport))) 2609 if (copy_from_user(&stl_dummyport, arg, sizeof(struct stlport)))
@@ -2629,11 +2623,12 @@ static int stl_getportstruct(struct stlport __user *arg)
2629 2623
2630static int stl_getbrdstruct(struct stlbrd __user *arg) 2624static int stl_getbrdstruct(struct stlbrd __user *arg)
2631{ 2625{
2626 struct stlbrd stl_dummybrd;
2632 struct stlbrd *brdp; 2627 struct stlbrd *brdp;
2633 2628
2634 if (copy_from_user(&stl_dummybrd, arg, sizeof(struct stlbrd))) 2629 if (copy_from_user(&stl_dummybrd, arg, sizeof(struct stlbrd)))
2635 return -EFAULT; 2630 return -EFAULT;
2636 if ((stl_dummybrd.brdnr < 0) || (stl_dummybrd.brdnr >= STL_MAXBRDS)) 2631 if (stl_dummybrd.brdnr >= STL_MAXBRDS)
2637 return -ENODEV; 2632 return -ENODEV;
2638 brdp = stl_brds[stl_dummybrd.brdnr]; 2633 brdp = stl_brds[stl_dummybrd.brdnr];
2639 if (!brdp) 2634 if (!brdp)