[BNX2]: Combine small mem allocations
Combine two small (56 byte and 320 byte) pci consistent memory allocations into one allocation. Jeff Garzik suggested to store the combined size in the bp structure for later use when freeing the memory. Use kzalloc() instead of kmalloc() + memset(). Signed-off-by: Michael Chan <mchan@broadcom.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
bf5295bba8
commit
0f31f99446
2 changed files with 17 additions and 19 deletions
|
@ -359,15 +359,11 @@ bnx2_free_mem(struct bnx2 *bp)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (bp->stats_blk) {
|
|
||||||
pci_free_consistent(bp->pdev, sizeof(struct statistics_block),
|
|
||||||
bp->stats_blk, bp->stats_blk_mapping);
|
|
||||||
bp->stats_blk = NULL;
|
|
||||||
}
|
|
||||||
if (bp->status_blk) {
|
if (bp->status_blk) {
|
||||||
pci_free_consistent(bp->pdev, sizeof(struct status_block),
|
pci_free_consistent(bp->pdev, bp->status_stats_size,
|
||||||
bp->status_blk, bp->status_blk_mapping);
|
bp->status_blk, bp->status_blk_mapping);
|
||||||
bp->status_blk = NULL;
|
bp->status_blk = NULL;
|
||||||
|
bp->stats_blk = NULL;
|
||||||
}
|
}
|
||||||
if (bp->tx_desc_ring) {
|
if (bp->tx_desc_ring) {
|
||||||
pci_free_consistent(bp->pdev,
|
pci_free_consistent(bp->pdev,
|
||||||
|
@ -392,14 +388,13 @@ bnx2_free_mem(struct bnx2 *bp)
|
||||||
static int
|
static int
|
||||||
bnx2_alloc_mem(struct bnx2 *bp)
|
bnx2_alloc_mem(struct bnx2 *bp)
|
||||||
{
|
{
|
||||||
int i;
|
int i, status_blk_size;
|
||||||
|
|
||||||
bp->tx_buf_ring = kmalloc(sizeof(struct sw_bd) * TX_DESC_CNT,
|
bp->tx_buf_ring = kzalloc(sizeof(struct sw_bd) * TX_DESC_CNT,
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
if (bp->tx_buf_ring == NULL)
|
if (bp->tx_buf_ring == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
memset(bp->tx_buf_ring, 0, sizeof(struct sw_bd) * TX_DESC_CNT);
|
|
||||||
bp->tx_desc_ring = pci_alloc_consistent(bp->pdev,
|
bp->tx_desc_ring = pci_alloc_consistent(bp->pdev,
|
||||||
sizeof(struct tx_bd) *
|
sizeof(struct tx_bd) *
|
||||||
TX_DESC_CNT,
|
TX_DESC_CNT,
|
||||||
|
@ -425,21 +420,22 @@ bnx2_alloc_mem(struct bnx2 *bp)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bp->status_blk = pci_alloc_consistent(bp->pdev,
|
/* Combine status and statistics blocks into one allocation. */
|
||||||
sizeof(struct status_block),
|
status_blk_size = L1_CACHE_ALIGN(sizeof(struct status_block));
|
||||||
|
bp->status_stats_size = status_blk_size +
|
||||||
|
sizeof(struct statistics_block);
|
||||||
|
|
||||||
|
bp->status_blk = pci_alloc_consistent(bp->pdev, bp->status_stats_size,
|
||||||
&bp->status_blk_mapping);
|
&bp->status_blk_mapping);
|
||||||
if (bp->status_blk == NULL)
|
if (bp->status_blk == NULL)
|
||||||
goto alloc_mem_err;
|
goto alloc_mem_err;
|
||||||
|
|
||||||
memset(bp->status_blk, 0, sizeof(struct status_block));
|
memset(bp->status_blk, 0, bp->status_stats_size);
|
||||||
|
|
||||||
bp->stats_blk = pci_alloc_consistent(bp->pdev,
|
bp->stats_blk = (void *) ((unsigned long) bp->status_blk +
|
||||||
sizeof(struct statistics_block),
|
status_blk_size);
|
||||||
&bp->stats_blk_mapping);
|
|
||||||
if (bp->stats_blk == NULL)
|
|
||||||
goto alloc_mem_err;
|
|
||||||
|
|
||||||
memset(bp->stats_blk, 0, sizeof(struct statistics_block));
|
bp->stats_blk_mapping = bp->status_blk_mapping + status_blk_size;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
|
@ -4083,6 +4083,8 @@ struct bnx2 {
|
||||||
|
|
||||||
struct flash_spec *flash_info;
|
struct flash_spec *flash_info;
|
||||||
u32 flash_size;
|
u32 flash_size;
|
||||||
|
|
||||||
|
int status_stats_size;
|
||||||
};
|
};
|
||||||
|
|
||||||
static u32 bnx2_reg_rd_ind(struct bnx2 *bp, u32 offset);
|
static u32 bnx2_reg_rd_ind(struct bnx2 *bp, u32 offset);
|
||||||
|
|
Loading…
Reference in a new issue