[PATCH 1/8] Char: moxa, remove unused allocated page
- From: Jiri Slaby <jirislaby@xxxxxxxxx>
- Date: Sun, 31 Dec 2006 02:04:19 +0100 (CET)
moxa, remove unused allocated page
moxaXmitBuff is almost unused -- only one byte from the whole PAGE_SIZE
bytes is used. Do not alloc so much space for almost anything. Also remove
lock protecting this page allocation.
Signed-off-by: Jiri Slaby <jirislaby@xxxxxxxxx>
---
commit fdcf97c855168c011b18ff68930bcc93e6c625c6
tree a87c0cef9ad40eb3ff2a981ecaa7ac08711809ac
parent c614729fee9638269d0881cf6ab895f19122225a
author Jiri Slaby <jirislaby@xxxxxxxxx> Sun, 31 Dec 2006 01:08:54 +0059
committer Jiri Slaby <jirislaby@xxxxxxxxx> Sun, 31 Dec 2006 01:08:54 +0059
drivers/char/moxa.c | 24 +-----------------------
1 files changed, 1 insertions(+), 23 deletions(-)
diff --git a/drivers/char/moxa.c b/drivers/char/moxa.c
index f391a24..4db1dc4 100644
--- a/drivers/char/moxa.c
+++ b/drivers/char/moxa.c
@@ -212,12 +212,10 @@ module_param(verbose, bool, 0644);
static struct tty_driver *moxaDriver;
static struct moxa_str moxaChannels[MAX_PORTS];
-static unsigned char *moxaXmitBuff;
static int moxaTimer_on;
static struct timer_list moxaTimer;
static int moxaEmptyTimer_on[MAX_PORTS];
static struct timer_list moxaEmptyTimer[MAX_PORTS];
-static struct semaphore moxaBuffSem;
/*
* static functions:
@@ -343,7 +341,6 @@ static int __init moxa_init(void)
if (!moxaDriver)
return -ENOMEM;
- init_MUTEX(&moxaBuffSem);
moxaDriver->owner = THIS_MODULE;
moxaDriver->name = "ttyMX";
moxaDriver->major = ttymajor;
@@ -360,8 +357,6 @@ static int __init moxa_init(void)
moxaDriver->flags = TTY_DRIVER_REAL_RAW;
tty_set_operations(moxaDriver, &moxa_ops);
- moxaXmitBuff = NULL;
-
for (i = 0, ch = moxaChannels; i < MAX_PORTS; i++, ch++) {
ch->type = PORT_16550A;
ch->port = i;
@@ -533,7 +528,6 @@ static int moxa_open(struct tty_struct *tty, struct file *filp)
struct moxa_str *ch;
int port;
int retval;
- unsigned long page;
port = PORTNO(tty);
if (port == MAX_PORTS) {
@@ -543,21 +537,6 @@ static int moxa_open(struct tty_struct *tty, struct file *filp)
tty->driver_data = NULL;
return (-ENODEV);
}
- down(&moxaBuffSem);
- if (!moxaXmitBuff) {
- page = get_zeroed_page(GFP_KERNEL);
- if (!page) {
- up(&moxaBuffSem);
- return (-ENOMEM);
- }
- /* This test is guarded by the BuffSem so no longer needed
- delete me in 2.5 */
- if (moxaXmitBuff)
- free_page(page);
- else
- moxaXmitBuff = (unsigned char *) page;
- }
- up(&moxaBuffSem);
ch = &moxaChannels[port];
ch->count++;
@@ -739,8 +718,7 @@ static void moxa_put_char(struct tty_struct *tty, unsigned char c)
return;
port = ch->port;
spin_lock_irqsave(&moxa_lock, flags);
- moxaXmitBuff[0] = c;
- MoxaPortWriteData(port, moxaXmitBuff, 1);
+ MoxaPortWriteData(port, &c, 1);
spin_unlock_irqrestore(&moxa_lock, flags);
/************************************************
if ( !(ch->statusflags & LOWWAIT) && (MoxaPortTxFree(port) <= 100) )
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
- Follow-Ups:
- [PATCH 7/8] Char: moxa, use PCI_DEVICE
- From: Jiri Slaby
- [PATCH 8/8] Char: moxa, eliminate typedefs
- From: Jiri Slaby
- [PATCH 5/8] Char: moxa, remove unused functions
- From: Jiri Slaby
- [PATCH 3/8] Char: moxa, timers cleanup
- From: Jiri Slaby
- [PATCH 4/8] Char: moxa, remove hangup bottomhalf
- From: Jiri Slaby
- [PATCH 2/8] Char: moxa, do not initialize global static
- From: Jiri Slaby
- [PATCH 6/8] Char: moxa, devids cleanup
- From: Jiri Slaby
- [PATCH 7/8] Char: moxa, use PCI_DEVICE
- Prev by Date: 2.6.20-rc2: known unfixed regressions (v2)
- Next by Date: [PATCH 6/8] Char: moxa, devids cleanup
- Previous by thread: Device does not have a release() function
- Next by thread: [PATCH 6/8] Char: moxa, devids cleanup
- Index(es):
Relevant Pages
- [PATCH 2/7] dlm: communication
... +static struct task_struct *recv_task; ... +static int nodeid_to_addr(int
nodeid, struct sockaddr *retaddr) ... +static void lowcomms_data_ready ... (Linux-Kernel) - [PATCH 3/8] dlm: communication
... +static struct task_struct *recv_task; ... +static int nodeid_to_addr(int
nodeid, struct sockaddr *retaddr) ... +static void make_sockaddr(struct sockaddr_storage
*saddr, uint16_t port, ... (Linux-Kernel) - [patch 07/15] Basic x86_64 support
... * Origianl kgdb, ... +int kgdb_remove_hw_break ... +static
struct pt_regs *in_interrupt_stack ... +/* Register KGDB with the die_chain so that
we hook into all of the right ... (Linux-Kernel) - [patch 3/3] Add support for X86_64 platforms to KGDB
... hooks or changes to x86_64-specific code, as well as the previous kgdb thread. ...
+int kgdb_remove_hw_break ... +static struct pt_regs *in_interrupt_stack ...
+/* Register KGDB with the die_chain so that we hook into all of the right ... (Linux-Kernel) - [2.6 patch] fs/nfsd/: possible cleanups
... +static int expkey_parse ... +static void svc_export_request(struct cache_detail
*cd, ... +static struct rpc_cred * ... -int nfsd_acceptable(void *expv, struct
dentry *dentry) ... (Linux-Kernel)