提交 aa7e5221 编写于 作者: J Jiri Slaby 提交者: Linus Torvalds

[PATCH] Char: moxa, timers cleanup

Use kernel macros and functions for timer encapsulation -- do not access
fileds directly.  Also del_timer on inactive is legal, so that noting if it
runs is senseless, delete these variables.
Signed-off-by: NJiri Slaby <jirislaby@gmail.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 9fa372a8
...@@ -210,13 +210,6 @@ module_param_array(numports, int, NULL, 0); ...@@ -210,13 +210,6 @@ module_param_array(numports, int, NULL, 0);
module_param(ttymajor, int, 0); module_param(ttymajor, int, 0);
module_param(verbose, bool, 0644); module_param(verbose, bool, 0644);
static struct tty_driver *moxaDriver;
static struct moxa_str moxaChannels[MAX_PORTS];
static int moxaTimer_on;
static struct timer_list moxaTimer;
static int moxaEmptyTimer_on[MAX_PORTS];
static struct timer_list moxaEmptyTimer[MAX_PORTS];
/* /*
* static functions: * static functions:
*/ */
...@@ -300,6 +293,10 @@ static const struct tty_operations moxa_ops = { ...@@ -300,6 +293,10 @@ static const struct tty_operations moxa_ops = {
.tiocmset = moxa_tiocmset, .tiocmset = moxa_tiocmset,
}; };
static struct tty_driver *moxaDriver;
static struct moxa_str moxaChannels[MAX_PORTS];
static DEFINE_TIMER(moxaTimer, moxa_poll, 0, 0);
static struct timer_list moxaEmptyTimer[MAX_PORTS];
static DEFINE_SPINLOCK(moxa_lock); static DEFINE_SPINLOCK(moxa_lock);
#ifdef CONFIG_PCI #ifdef CONFIG_PCI
...@@ -372,17 +369,11 @@ static int __init moxa_init(void) ...@@ -372,17 +369,11 @@ static int __init moxa_init(void)
put_tty_driver(moxaDriver); put_tty_driver(moxaDriver);
return -1; return -1;
} }
for (i = 0; i < MAX_PORTS; i++) { for (i = 0; i < MAX_PORTS; i++)
init_timer(&moxaEmptyTimer[i]); setup_timer(&moxaEmptyTimer[i], check_xmit_empty,
moxaEmptyTimer[i].function = check_xmit_empty; (unsigned long)&moxaChannels[i]);
moxaEmptyTimer[i].data = (unsigned long) & moxaChannels[i];
}
init_timer(&moxaTimer); mod_timer(&moxaTimer, jiffies + HZ / 50);
moxaTimer.function = moxa_poll;
moxaTimer.expires = jiffies + (HZ / 50);
moxaTimer_on = 1;
add_timer(&moxaTimer);
/* Find the boards defined in source code */ /* Find the boards defined in source code */
numBoards = 0; numBoards = 0;
...@@ -468,12 +459,10 @@ static void __exit moxa_exit(void) ...@@ -468,12 +459,10 @@ static void __exit moxa_exit(void)
if (verbose) if (verbose)
printk("Unloading module moxa ...\n"); printk("Unloading module moxa ...\n");
if (moxaTimer_on) del_timer(&moxaTimer);
del_timer(&moxaTimer);
for (i = 0; i < MAX_PORTS; i++) for (i = 0; i < MAX_PORTS; i++)
if (moxaEmptyTimer_on[i]) del_timer(&moxaEmptyTimer[i]);
del_timer(&moxaEmptyTimer[i]);
if (tty_unregister_driver(moxaDriver)) if (tty_unregister_driver(moxaDriver))
printk("Couldn't unregister MOXA Intellio family serial driver\n"); printk("Couldn't unregister MOXA Intellio family serial driver\n");
...@@ -589,7 +578,6 @@ static void moxa_close(struct tty_struct *tty, struct file *filp) ...@@ -589,7 +578,6 @@ static void moxa_close(struct tty_struct *tty, struct file *filp)
if (ch->asyncflags & ASYNC_INITIALIZED) { if (ch->asyncflags & ASYNC_INITIALIZED) {
setup_empty_event(tty); setup_empty_event(tty);
tty_wait_until_sent(tty, 30 * HZ); /* 30 seconds timeout */ tty_wait_until_sent(tty, 30 * HZ); /* 30 seconds timeout */
moxaEmptyTimer_on[ch->port] = 0;
del_timer(&moxaEmptyTimer[ch->port]); del_timer(&moxaEmptyTimer[ch->port]);
} }
shut_down(ch); shut_down(ch);
...@@ -885,14 +873,10 @@ static void moxa_poll(unsigned long ignored) ...@@ -885,14 +873,10 @@ static void moxa_poll(unsigned long ignored)
struct tty_struct *tp; struct tty_struct *tp;
int i, ports; int i, ports;
moxaTimer_on = 0;
del_timer(&moxaTimer); del_timer(&moxaTimer);
if (MoxaDriverPoll() < 0) { if (MoxaDriverPoll() < 0) {
moxaTimer.function = moxa_poll; mod_timer(&moxaTimer, jiffies + HZ / 50);
moxaTimer.expires = jiffies + (HZ / 50);
moxaTimer_on = 1;
add_timer(&moxaTimer);
return; return;
} }
for (card = 0; card < MAX_BOARDS; card++) { for (card = 0; card < MAX_BOARDS; card++) {
...@@ -932,10 +916,7 @@ static void moxa_poll(unsigned long ignored) ...@@ -932,10 +916,7 @@ static void moxa_poll(unsigned long ignored)
} }
} }
moxaTimer.function = moxa_poll; mod_timer(&moxaTimer, jiffies + HZ / 50);
moxaTimer.expires = jiffies + (HZ / 50);
moxaTimer_on = 1;
add_timer(&moxaTimer);
} }
/******************************************************************************/ /******************************************************************************/
...@@ -1062,11 +1043,7 @@ static void setup_empty_event(struct tty_struct *tty) ...@@ -1062,11 +1043,7 @@ static void setup_empty_event(struct tty_struct *tty)
spin_lock_irqsave(&moxa_lock, flags); spin_lock_irqsave(&moxa_lock, flags);
ch->statusflags |= EMPTYWAIT; ch->statusflags |= EMPTYWAIT;
moxaEmptyTimer_on[ch->port] = 0; mod_timer(&moxaEmptyTimer[ch->port], jiffies + HZ);
del_timer(&moxaEmptyTimer[ch->port]);
moxaEmptyTimer[ch->port].expires = jiffies + HZ;
moxaEmptyTimer_on[ch->port] = 1;
add_timer(&moxaEmptyTimer[ch->port]);
spin_unlock_irqrestore(&moxa_lock, flags); spin_unlock_irqrestore(&moxa_lock, flags);
} }
...@@ -1075,7 +1052,6 @@ static void check_xmit_empty(unsigned long data) ...@@ -1075,7 +1052,6 @@ static void check_xmit_empty(unsigned long data)
struct moxa_str *ch; struct moxa_str *ch;
ch = (struct moxa_str *) data; ch = (struct moxa_str *) data;
moxaEmptyTimer_on[ch->port] = 0;
del_timer(&moxaEmptyTimer[ch->port]); del_timer(&moxaEmptyTimer[ch->port]);
if (ch->tty && (ch->statusflags & EMPTYWAIT)) { if (ch->tty && (ch->statusflags & EMPTYWAIT)) {
if (MoxaPortTxQueue(ch->port) == 0) { if (MoxaPortTxQueue(ch->port) == 0) {
...@@ -1083,9 +1059,7 @@ static void check_xmit_empty(unsigned long data) ...@@ -1083,9 +1059,7 @@ static void check_xmit_empty(unsigned long data)
tty_wakeup(ch->tty); tty_wakeup(ch->tty);
return; return;
} }
moxaEmptyTimer[ch->port].expires = jiffies + HZ; mod_timer(&moxaEmptyTimer[ch->port], jiffies + HZ);
moxaEmptyTimer_on[ch->port] = 1;
add_timer(&moxaEmptyTimer[ch->port]);
} else } else
ch->statusflags &= ~EMPTYWAIT; ch->statusflags &= ~EMPTYWAIT;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册