[U-Boot] [PATCH] nios2: nios2-generic: do not allocate rx buf in net.c

Do not allocate rx buf in net.c, because altera_tse allocates its own rx buf in driver. This can save 6KB memory.
Signed-off-by: Thomas Chou thomas@wytron.com.tw --- include/configs/nios2-generic.h | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/include/configs/nios2-generic.h b/include/configs/nios2-generic.h index 4569de8..856c836 100644 --- a/include/configs/nios2-generic.h +++ b/include/configs/nios2-generic.h @@ -33,8 +33,9 @@ #define CONFIG_SYS_MAX_FLASH_SECT 512
/* - * MII/PHY + * NET options */ +#define CONFIG_SYS_RX_ETH_BUFFER 0 #define CONFIG_CMD_MII #define CONFIG_PHY_GIGE #define CONFIG_SYS_FAULT_ECHO_LINK_DOWN

On Thursday, November 05, 2015 at 09:42:43 AM, Thomas Chou wrote:
Do not allocate rx buf in net.c, because altera_tse allocates its own rx buf in driver. This can save 6KB memory.
Signed-off-by: Thomas Chou thomas@wytron.com.tw
Shouldn't we instead fix the altera driver to use the pre-allocated buffer ?
Best regards, Marek Vasut

Hi Marek,
On 2015年11月06日 00:16, Marek Vasut wrote:
On Thursday, November 05, 2015 at 09:42:43 AM, Thomas Chou wrote:
Do not allocate rx buf in net.c, because altera_tse allocates its own rx buf in driver. This can save 6KB memory.
Signed-off-by: Thomas Chou thomas@wytron.com.tw
Shouldn't we instead fix the altera driver to use the pre-allocated buffer ?
It should not. The drivers and devices are dynamically binding in driver model. The buffers used by devices should be allocated per device. Eg, there may be multiple ethernet devices and they should not use the same pre-allocated rx bufs.
Best regards, Thomas

On Friday, November 06, 2015 at 12:47:13 AM, Thomas Chou wrote:
Hi Marek,
Hi!
On 2015年11月06日 00:16, Marek Vasut wrote:
On Thursday, November 05, 2015 at 09:42:43 AM, Thomas Chou wrote:
Do not allocate rx buf in net.c, because altera_tse allocates its own rx buf in driver. This can save 6KB memory.
Signed-off-by: Thomas Chou thomas@wytron.com.tw
Shouldn't we instead fix the altera driver to use the pre-allocated buffer ?
It should not. The drivers and devices are dynamically binding in driver model. The buffers used by devices should be allocated per device. Eg, there may be multiple ethernet devices and they should not use the same pre-allocated rx bufs.
Oh ok, I see your point now. But then, this allocation of buffers in the ethernet drivers becomes a boilerplate code, right ? So maybe there should be some mechanism in the network stack to allocate the buffers for the drivers to prevent duplication of code.
What do you think?
Best regards, Marek Vasut

Hi Marek,
On 2015年11月06日 09:40, Marek Vasut wrote:
On Friday, November 06, 2015 at 12:47:13 AM, Thomas Chou wrote:
Hi Marek,
Hi!
On 2015年11月06日 00:16, Marek Vasut wrote:
On Thursday, November 05, 2015 at 09:42:43 AM, Thomas Chou wrote:
Do not allocate rx buf in net.c, because altera_tse allocates its own rx buf in driver. This can save 6KB memory.
Signed-off-by: Thomas Chou thomas@wytron.com.tw
Shouldn't we instead fix the altera driver to use the pre-allocated buffer ?
It should not. The drivers and devices are dynamically binding in driver model. The buffers used by devices should be allocated per device. Eg, there may be multiple ethernet devices and they should not use the same pre-allocated rx bufs.
Oh ok, I see your point now. But then, this allocation of buffers in the ethernet drivers becomes a boilerplate code, right ? So maybe there should be some mechanism in the network stack to allocate the buffers for the drivers to prevent duplication of code.
The pre-alloacted tx_buf is still in use by net/ . But most ethernet drivers allocate their own rx_buf (perhaps as ring buffer). Most of them use memalign(PKTSIZE_ALIGN), which is the same as malloc_cache_aligned(PKTSIZE_ALIGN). Each driver may have different requirement of size/number of the rx buf.
The driver passes the rx buf to net/ . And the net/ return the rx buf with free_pkt() to the driver after use.
I think this scheme works fine. There not much duplication of code for rx_buf allocation, which might be only a malloc_cache_aligned().
Best regards, Thomas
participants (2)
-
Marek Vasut
-
Thomas Chou