Forum: Mikrocontroller und Digitale Elektronik lwip Raw Tcp direktes senden erzwingen


von Kilian K. (kellermaaan)


Lesenswert?

Hallo zusammen,

ich habe eine Frage zu dem lwIP-Stack und dem Raw Tcp. Gibt es eine 
Möglichkeit das Senden zu erzwingen? In meinem Fall ist es nämlich so, 
die Bearbeitung eines über TCP empfangenden Befehls dauert immer 56ms. 
Aber auf der Gegenseite empfange ich die Antwort entweder schon (wenn es 
gut läuft) nach 47ms aber meistens nach 62-63ms. Das dauert mir 
allerdings bisschen zulange. Ich habe die Vermutung, dass der Stack auf 
irgendetwas beim Senden wartet.

Hier mal meine Methoden zum senden:
1
/** Send data
2
* @param pointer to scpi session data
3
*/
4
static err_t scpi_send_next_data(tcp_pcb *data_pcb)
5
{
6
  const char *scpi_data;
7
  int len = 0;
8
  void *dummy;
9
10
  len = file_source(dummy, &scpi_data, data_pcb->mss);
11
  if (len) {
12
    tcp_write(data_pcb, scpi_data, len, 0);
13
  }
14
15
  return ERR_OK;
16
}
1
/** Handle data connection acknowledge of sent data
2
* @param pointer to scpi session data
3
* @param pointer to PCB
4
* @param number of bytes sent
5
*/
6
err_t scpi_sent(void *arg, struct tcp_pcb *tpcb, u16_t len)
7
{
8
  struct echo_state *es;
9
  void *dummy;
10
11
  LWIP_UNUSED_ARG(len);
12
13
  es = (struct echo_state *)arg;
14
  es->retries = 0;
15
16
  file_source(dummy, NULL, len);
17
18
  return scpi_send_next_data(es->pcb);
19
}
In der Methode
1
file_source()
 hole ich mir einfach nur die Daten die zurückgeschickt werden sollen.

Ich hoffe hier ist jemand der mir helfen kann!

Gruß Kilian

von Fred (Gast)


Lesenswert?

Hallo Kilian,

setze ein tcp_output nach tcp_write. Damit wird der Stack aufgefordert 
die Daten sofort zu senden. Andernfalls wird gewartet bis der 
Sende-Buffer voll ist oder eine gewiße Zeit abgelaufen ist.

von Kilian K. (kellermaaan)


Lesenswert?

Hallo Fred,
erstaml danke für deine Antwort.
Das mit dem tcp_output hatte ich schon einmal probiert aber irgendwie 
hat das nicht viel geholfen... Die Zeit war genauso lange.

Gruß Kilian

von Läubi .. (laeubi) Benutzerseite


Lesenswert?

Kilian K. schrieb:
> Das dauert mir allerdings bisschen zulange. Ich habe die Vermutung, dass
> der Stack auf irgendetwas beim Senden wartet.

Nicht vermuten sondern prüfen!

von fb (Gast)


Lesenswert?

Läubi .. schrieb:
> Nicht vermuten sondern prüfen!

Viel zu prüfen gibts da eigentlich nicht.
Da wohl auch der lwIP-Stack den Nagle-Algorithmus implementiert wäre es 
eher ungewöhnlich, wenn beim Senden kleiner Datenhäppchen keine 
Wartezeit auftritt. Könnte man bei lwIP mit 'tcp_nagle_disable' 
ausschalten. Wenn die Gegenseite auch nur kleine Häppchen sendet, sollte 
man das dort ebenfalls tun. Oder falls möglich auf UDP umsteigen.

von Kilian K. (kellermaaan)


Lesenswert?

Also mit tcp_output() und 'tcp_nagle_disable' funktioniert es. Nur das 
Problem ist jetzt, mein Webserver ist dadurch nicht mehr erreichbar, 
obwohl es ein ganz anderer Part und Struktur ist... Kann man die 
irgendwie voneinander trennen?

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.