[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <D7CCA83BB0796C49BC0BB53B6AB1208934920A@zch01exm21.fsl.freescale.net>
Date: Wed, 27 May 2009 13:08:07 +0800
From: "Liu Dave-R63238" <DaveLiu@...escale.com>
To: <netdev@...r.kernel.org>
Cc: <linux-kernel@...r.kernel.org>, <linuxppc-dev@...abs.org>
Subject: Net: ucc_geth ethernet driver optimization space
Guys,
The ucc_geth ethernet driver have dozens of strong sync read/write
operation, such as in_be32/16/8, out_be32/16/8.
all of them is sync read/write, it is very expensive for performance.
For the critical patch, we can remove some unnecessary in_be(x),
out_be(x) with normal memory operation, and keep some necessary
memory barrier.
eg: BD access in the interrupt handler and start_xmit.
The BD operation only need the memory barrier between length/buffer
and status.
struct buffer descriptor {
u16 status;
u16 length;
u32 buffer;
} __attribute__ ((packed));
struct buffer descriptor *BD;
BD->length = xxxx;
BD->buffer = yyyy;
wmb();
BD->status = zzzz;
For powerpc, eieio is enough for 60x, mbar 1 is enough for e500.
Of couse, also need the memory clobber to avoid the compiler
reorder between them.
Thanks, Dave
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists