Forum: Compiler & IDEs uIP Statemachine


von Josef K. (josefk)


Lesenswert?

Hallo zusammen,

ich habe eine kleine Frage zum uIP Stack bzw zu dessen Nutzung. Ich habe 
gerade versucht, nach dem Beispiel von Simon Kuepers, einen kleinen 
Webserver in Betrieb zu nehmen.
Hierzu meine Funktionen, die hier evtl interessant sind:
1
void eth_listen(void)
2
{
3
  eth_flag = 0;
4
  uip_listen(HTONS(500));
5
  uip_listen(HTONS(80));
6
}
1
void statemachine(void) 
2
{
3
  if (uip_connected())
4
  {
5
    rs232_puts("statemachine connected");
6
    eth_flag = uipflag_connected;
7
  }
8
  else if (uip_newdata() || uip_acked())
9
  {
10
    rs232_puts("statemachine new ack");
11
    switch(uip_conn->lport) 
12
      {
13
        case HTONS(500):
14
        irgendwasanderes(uip_appdata);
15
        break;
16
        
17
        case HTONS(80):
18
        http_server(uip_appdata);
19
        break;
20
        
21
        default: break;
22
     }
23
  }
24
  else if (uip_rexmit())
25
  {
26
    rs232_puts("statemachine rexmit");
27
    //schau ma mal später
28
    uip_abort();
29
  }
30
}

Doch leider gelange ich nie in die zweite Bedingung der Statemachine. 
Weder "acked" noch "newdata" treten ein. Sobald ich von Seiten des PCs 
eine GET Anfrage auf den µC schicke, komme ich in die erste Bedinung, 
danach sendet der PC nur noch "[TCP] Rtransmission] GET / HHTP/1.1".
Wenn ich mir mal uip_appdata ausgeben lasse, sobald ich ein "connected" 
habe, ist das nur ein String mit '\0' beginnend.
Was mach ich da falsch? Das sollte doch prinzipiell funktionieren, oder?

von Josef K. (josefk)


Angehängte Dateien:

Lesenswert?

Hier noch ein Bild, dass den Mitschnitt mit Wireshark anzeigt.

von Simon K. (simon) Benutzerseite


Lesenswert?

Ich kann im Moment leider keinen Grund dafür sehen, warum es nicht 
funktionieren sollte, um ehrlich zu sein. Kannst du das ganze Projekt 
mal anhängen?

Rufst du "eth_listen()" auch irgendwo auf?

von Josef K. (josefk)


Angehängte Dateien:

Lesenswert?

Habs mal angehängt und auf das "Nötigste" gekürzt. :)

von Simon K. (simon) Benutzerseite


Lesenswert?

Uff! Ich dachte du hättest erstmal nur probiert den ganzen 
Ethernet-Krams in einem eigenen Projekt auf Funktion zu testen. Das 
macht die Sache ja um einiges komplizierter, da man nicht weiß ob ein 
anderer Code-Teil das Problem auftauchen lässt.

von Josef K. (josefk)


Lesenswert?

Aber eiegtnlcih sollte da ja sonst nix passieren. Kann es sein, dass ich 
zu wenig Ram über habe für den Stack?
Hab nen AT90CAN128 und meine Prog. erzeugt das:
1
main.elf  :
2
section             size      addr
3
.data               2140   8388864
4
.text              78872         0
5
.bss                3115   8391004
6
.eeprom               65   8454144
7
.stab              59388         0
8
.stabstr           31497         0
9
.debug_aranges       180         0
10
.debug_pubnames     2334         0
11
.debug_info        10873         0
12
.debug_abbrev       2870         0
13
.debug_line         8509         0
14
.debug_str          2510         0
15
.debug_ranges         92         0
16
Total             202445

Zu Meiner Verteidigung muss ich sagen, dass ich 32k externen Ram habe, 
den ich hoffentlich mit
1
# 32 KB of external RAM, starting after internal RAM (ATmega128!),
2
# used for variables (.data/.bss) and heap (malloc()).
3
EXTMEMOPTS = -Wl,-Tdata=0x801100,--defsym=__heap_end=0x808fff
anspreche.

von Josef K. (josefk)


Lesenswert?

Hmm. Scheint an dem AtmegaDos zu liegen. Sobald ich das weglasse 
funktioniert alles einwandfrei. Nur was daran stört?

von Josef K. (josefk)


Lesenswert?

Also es liegt am RAM. Sobald ich über den internen RAM voll hab, geht 
nix mehr.

Wie gesagt, ich habe meinen externen RAM mit
1
# 32 KB of external RAM, starting after internal RAM (ATmega128!),
2
# used for variables (.data/.bss) and heap (malloc()).
3
EXTMEMOPTS = -Wl,-Tdata=0x801100,--defsym=__heap_end=0x808fff
versucht in mein Projekt einzubinden. Anscheinend geht das nicht.
Da muss ich wohl suchen wie man das richtig macht....

von Thorsten (Gast)


Lesenswert?

Hast du das externe Speicherinterface dann auch eingeschaltet?
Das kann man afaik in irgendeiner init section beim startup mitmachen 
lassen. 100%ig weiß ich das auch nicht mehr.

Gruß

von Simon K. (simon) Benutzerseite


Lesenswert?

Thorsten wrote:
> Das kann man afaik in irgendeiner init section beim startup mitmachen
> lassen.

Musst du sogar, soweit ich das weiß. Schau mal hier:
http://www.nongnu.org/avr-libc/user-manual/FAQ.html#faq_ext_ram

von Josef K. (josefk)


Lesenswert?

Ahh danke.

Habe das auf Rat so gemacht:
1
;; begin xram.S
2
;; Aktivierung des externen Memeory-Interfaces
3
#include <avr/io.h>
4
5
 .section .init1,"ax",@progbits
6
7
;;      entspricht XMCRA = ((1<<SRL2) | (1<<SRW11) | (1<<SRW10) | (1<<SRE));  
8
9
 ldi r16,_BV(SRE) | _BV(SRW10) | _BV(SRW11) | _BV(SRL2)
10
 sts XMCRA,r16
11
 
12
13
;; end xram.S
und dann diese xram.s noch in das makefile eingebunden. Zusätzlich ist 
obige Option
1
# 32 KB of external RAM, starting after internal RAM (ATmega128!),
2
# used for variables (.data/.bss) and heap (malloc()).
3
EXTMEMOPTS = -Wl,-Tdata=0x801100,--defsym=__heap_end=0x808fff
geblieben.

Nun sollte ich mit malloc() problemlos Speicher reserverien können, der 
außerhalb meines internen Speicherbereiches liegt.
Leider funktioniert das nicht so wie gewünscht. Laut Datasheet sehen die 
obigen Konfigurationen aber vernünftig aus.
Die Konfiguratin hier 
http://www.nongnu.org/avr-libc/user-manual/FAQ.html#faq_startup sieht 
zwar anders aus, scheint aber für den AT90CAN128 nicht vernünftig, da 
das MCUCR Register keine SRE oder SRW Flags hat ;)

Was ist noch falsch????

von Josef K. (josefk)


Lesenswert?

Habe dazu mal einen neuen Thread aufgemacht:

Beitrag "externen RAM testen"

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.