реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> помогите с uIP стеком, проблема с uip_split
Scuby
сообщение Dec 23 2010, 05:44
Сообщение #1


Частый гость
**

Группа: Участник
Сообщений: 98
Регистрация: 11-11-08
Пользователь №: 41 528



Здравствуйте
в стеке uIP хочу воспользоваться uip_split для деления пакетов чтоб отключить задежку ответа и увеличить скорость хотя бы до 50 килобайт в сек.
сейчас 5кб/сек. но никак не могу понять как ей пользоваться. в документации написано в стиле "вот есть такая функция"
но КАК ее использовать? может ктото использовал. подскажите пожалуйста
Go to the top of the page
 
+Quote Post
etoja
сообщение Dec 23 2010, 07:09
Сообщение #2


Профессионал
*****

Группа: Свой
Сообщений: 1 121
Регистрация: 14-01-05
Из: Москва
Пользователь №: 1 952



uIP поставляется в исходных текстах и по ним можно разобраться.
Если речь о GPRS соединении, то 5Кбайт/сек это очень хорошо и 50 не получить.
Go to the top of the page
 
+Quote Post
Scuby
сообщение Dec 23 2010, 11:29
Сообщение #3


Частый гость
**

Группа: Участник
Сообщений: 98
Регистрация: 11-11-08
Пользователь №: 41 528



Цитата(etoja @ Dec 23 2010, 15:09) *
uIP поставляется в исходных текстах и по ним можно разобраться.
Если речь о GPRS соединении, то 5Кбайт/сек это очень хорошо и 50 не получить.

конечно, это очевидно
если бы я мог запросто разобраться я бы не спрашивал
про GPRS аналогично. у меня Ethernet

проблема в ACK Delay 200мс который преодолевается данной коммандой, но почемуто не могу ее запустить. вот и спрашиваю чтоб разобраться как ей правильно пользоваться т.к. подробного описания в инструкции нет
Go to the top of the page
 
+Quote Post
MiniMax
сообщение Dec 23 2010, 17:18
Сообщение #4


Участник
*

Группа: Участник
Сообщений: 53
Регистрация: 12-09-07
Пользователь №: 30 498



Цитата(Scuby @ Dec 23 2010, 17:29) *
конечно, это очевидно
если бы я мог запросто разобраться я бы не спрашивал
про GPRS аналогично. у меня Ethernet

проблема в ACK Delay 200мс который преодолевается данной коммандой, но почемуто не могу ее запустить. вот и спрашиваю чтоб разобраться как ей правильно пользоваться т.к. подробного описания в инструкции нет


Я делал так
Код
    
.....
#ifdef    UIP_SPLIT_TCP_PACKET
    uip_split_output();
#else                            
    ethernet_send();
#endif    

....
#define BUF ((uip_tcpip_hdr *)&uip_buf[UIP_LLH_LEN])

/*-----------------------------------------------------------------------------*/
void
uip_split_output(void)
{
  u16_t tcplen, len1, len2;

  /* We only try to split maximum sized TCP segments. */
  if(BUF->proto == UIP_PROTO_TCP && (uip_len > MAX_IEEE_LENGTH))
  {

    uip_len -= UIP_LLH_LEN;
    tcplen = uip_len - UIP_TCPIP_HLEN;
    /* Split the segment in two. If the original packet length was
       odd, we make the second packet one byte larger. */
    len1 = len2 = tcplen / 2;
    if(len1 + len2 < tcplen) {
      ++len2;
    }
    /* Create the first packet. This is done by altering the length
       field of the IP header and updating the checksums. */
    uip_len = len1 + UIP_TCPIP_HLEN;
    BUF->len[0] = (uip_len >> 8);
    BUF->len[1] = (uip_len & 0xff);
    
    /* Recalculate the TCP checksum. */
    BUF->tcpchksum = 0;
    BUF->tcpchksum = ~(uip_tcpchksum());
    
    /* Recalculate the IP checksum. */
    BUF->ipchksum = 0;
    BUF->ipchksum = ~(uip_ipchksum());

    /* Transmit the first packet. */
    uip_len += UIP_LLH_LEN;
    ethernet_send();

    /* Now, create the second packet. To do this, it is not enough to
       just alter the length field, but we must also update the TCP
       sequence number and point the uip_appdata to a new place in
       memory. This place is detemined by the length of the first
       packet (len1). */
    uip_len = len2 + UIP_TCPIP_HLEN;
    BUF->len[0] = (uip_len >> 8);
    BUF->len[1] = (uip_len & 0xff);

    uip_appdata += len1;

    uip_add32(BUF->seqno, len1);
    BUF->seqno[0] = uip_acc32[0];
    BUF->seqno[1] = uip_acc32[1];
    BUF->seqno[2] = uip_acc32[2];
    BUF->seqno[3] = uip_acc32[3];
    
    /* Recalculate the TCP checksum. */
    BUF->tcpchksum = 0;
    BUF->tcpchksum = ~(uip_tcpchksum());
    
    /* Recalculate the IP checksum. */
    BUF->ipchksum = 0;
    BUF->ipchksum = ~(uip_ipchksum());

    /* Transmit the second packet. */
       uip_len += UIP_LLH_LEN;
    ethernet_send();
    uip_len == UIP_BUFSIZE;
  } else {
      ethernet_send();
  }
}
Go to the top of the page
 
+Quote Post
Scuby
сообщение Dec 24 2010, 09:42
Сообщение #5


Частый гость
**

Группа: Участник
Сообщений: 98
Регистрация: 11-11-08
Пользователь №: 41 528



спасибо большое! все заработало
высянилось что в оригинальных исходниках немного по другому подсчитывается размер.
Видимо поэтому и проблемы были

мне осталось только не совсем понятно почему в исходниках режутся только пакеты максимальной длины
Go to the top of the page
 
+Quote Post
MiniMax
сообщение Dec 24 2010, 18:24
Сообщение #6


Участник
*

Группа: Участник
Сообщений: 53
Регистрация: 12-09-07
Пользователь №: 30 498



Цитата(Scuby @ Dec 24 2010, 15:42) *
мне осталось только не совсем понятно почему в исходниках режутся только пакеты максимальной длины

Большие пакеты в моем проекте относятся к TCP/IP. Меньшие пакеты могут относиться к ICMP, ARP. Эти незачем резать.
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 21st July 2025 - 09:28
Рейтинг@Mail.ru


Страница сгенерированна за 0.01392 секунд с 7
ELECTRONIX ©2004-2016