| /* |
| * Definitions for the 'struct sk_buff' memory handlers in U-Boot. |
| * |
| * (C) Copyright 2003 |
| * Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
| * |
| * See file CREDITS for list of people who contributed to this |
| * project. |
| * |
| * This program is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU General Public License as |
| * published by the Free Software Foundation; either version 2 of |
| * the License, or (at your option) any later version. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| * You should have received a copy of the GNU General Public License |
| * along with this program; if not, write to the Free Software |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, |
| * MA 02111-1307 USA |
| */ |
| |
| #include <config.h> |
| |
| #ifdef CONFIG_SK98 |
| |
| #include <common.h> |
| #include "u-boot_compat.h" |
| |
| #define MAX_SKB 128 |
| |
| struct sk_buff *sk_table[MAX_SKB]; |
| |
| unsigned int skbAlloc=0,skbFree=0; |
| /*unsigned int cntrMalloc=0,cntrFree=0; |
| unsigned int indxMalloc=0,indxFree=0; |
| */ |
| |
| extern int tftpCount; |
| struct sk_buff * alloc_skb(u32 size, int dummy) |
| { |
| int i; |
| struct sk_buff * ret = NULL; |
| |
| if(0)/*if(tftpCount == 2)*/ |
| { |
| printf("alloc_skb , size=%d\n",size); |
| } |
| for (i = 0; i < MAX_SKB; i++) |
| { |
| if (sk_table[i]) |
| { |
| /* Already allocated. |
| */ |
| continue; |
| } |
| |
| sk_table[i] = malloc(sizeof(struct sk_buff)); |
| if (! sk_table[i]) |
| { |
| printf("alloc_skb: malloc failed\n"); |
| break; |
| } |
| |
| memset(sk_table[i], 0, sizeof(struct sk_buff)); |
| sk_table[i]->data = sk_table[i]->data_unaligned = |
| malloc(size + 16); |
| if (! sk_table[i]->data) |
| { |
| printf("alloc_skb: malloc failed\n"); |
| free(sk_table[i]); |
| sk_table[i] = NULL; |
| break; |
| } |
| |
| sk_table[i]->data += 16 - ((u32)sk_table[i]->data & 15); |
| sk_table[i]->len = size; |
| |
| break; |
| } |
| |
| if (i < MAX_SKB) |
| { |
| ret = sk_table[i]; |
| } |
| |
| if(0)/*if(tftpCount == 2)*/ |
| { |
| printf("alloc_skb , i=%d sk_table[i]=0x%x sk_table[i]->data=0x%x\n",i,(unsigned int)sk_table[i],(unsigned int)sk_table[i]->data); |
| } |
| |
| |
| if (! ret) |
| { |
| printf("Unable to allocate skb!\n"); |
| } |
| else |
| { |
| skbAlloc++;; |
| } |
| |
| return ret; |
| } |
| |
| void dev_kfree_skb_any(struct sk_buff *skb) |
| { |
| int i; |
| |
| if(0)/*if(tftpCount == 2)*/ |
| { |
| printf("dev_kfree_skb_any , skb=0x%x\n",(unsigned int)skb); |
| } |
| |
| |
| for (i = 0; i < MAX_SKB; i++) |
| { |
| if (sk_table[i] != skb) |
| { |
| continue; |
| } |
| if(0)/*if(tftpCount == 2)*/ |
| { |
| printf("dev_kfree_skb_any , i=%d sk_table[i]=0x%x sk_table[i]->data=0x%x\n",i,(unsigned int)skb,(unsigned int)skb->data_unaligned); |
| } |
| |
| |
| free(skb->data_unaligned); |
| free(skb); |
| sk_table[i] = NULL; |
| break; |
| } |
| |
| if (i == MAX_SKB) |
| { |
| printf("SKB allocation error!\n"); |
| } |
| else |
| { |
| skbFree++; |
| } |
| } |
| |
| void skb_reserve(struct sk_buff *skb, unsigned int len) |
| { |
| skb->data+=len; |
| } |
| |
| void skb_put(struct sk_buff *skb, unsigned int len) |
| { |
| skb->len+=len; |
| } |
| |
| |
| |
| |
| #endif /* CONFIG_SK98 */ |