Forum: Mikrocontroller und Digitale Elektronik printf Problem ARM mit Crossworks


von Christian J. (elektroniker1968)


Lesenswert?

Hallo,

leider kommt der alte Beitrag nicht mehr hoch, daher ein neuer:

Crosssworks kennt die printf Funktion wie gehabt durch den gcc und
leitet sie in einer internen Bibliothek auf __debug_printf() um, das ist
die für diese Entwicklungsumgebung definierte Debug Schnittstelle, die
über das JTAG Interface auf ein virtuelles Terminal schreibt. Diese
Funktion ist nicht portierbar. Sehr nützlich für die
Programmentwicklung, es lassen sich auch Dateien damit auf die Platte
schreiben... aber eben nur wenn der JTAG Stecker drin ist und Debug
Infos mit kompiliert wurden.

Der Prototyp von putchar heisst: int __putchar(int ch) und liegt in der
stdio.h drin. Alles was dahinter kommt liegt nur als Object File vor.
Die Hilfe gibt leider auch nicht viel her.
1
If you need to output to a physical device, such as a UART, the following 
2
notes will help you:
3
4
* If the character cannot be written for any reason, putchar must return EOF.
5
6
* The higher layers of the library do not translate C's end of line 
7
character '\n' before passing it to putchar. If you are directing output 
8
to a serial line connected to a terminal, for instance, you will most 
9
likely need to output a carriage return and line feed when given the 
10
character '\n' (ASCII code 10).

Heisst das jetzt, dass ich nur die __putchar Funktion überschreiben
muss, dort drin meinen Uart Code plazieren und die Sonderzeichen
gesondert erzeugen muss?

Die andere Sache ist die Schreibweise von Interruptfunktionen. Koch da
eigentlich jeder sein Süppchen, also zB keil anders als gcc usw?

Bei mir sieht ein Prototyp für eine ISR so aus:

static void attribute ((interrupt("IRQ"))) timer0ISR(void);

(wobei ich den Sinn hinter dem Attrbute nicht verstehe...)

Eingeschaltet werden sie mit: __ARMLIB_enableIRQ();

Bei Keil wieder so mit dem Keyword _irq.

void UART0Handler( void ) __irq;

von Stephan (Gast)


Lesenswert?

Hi,

ja du kannst die Funktion überschreiben.
Ich bevorzuge aber eher die Methode:
1
Whilst this is an adequate implementation of __putchar, it does consume
2
stack space for an unnecessary nested call and associated register saving.
3
A better way of achieving the same result is to define the low-level symbol
4
for __putchar to be equivalent to the low-level symbol for debug_putchar.
5
To do this, we need to instruct the linker to make the symbols equivalent.

schau dir nochmal dafür die Doku im Netz an.

mfg

Stephan

von Christian J. (Gast)


Lesenswert?

Hallo,

funktioniert leider nicht __putchar irgendwo im Code zu definieren, 
printf bleibt weiter auf der Debug Schnittstelle.

Was gut funktioniert ist das
1
void uprintf(char *s, const char *format, ...)
2
{
3
    unsigned char textbuf[80];
4
5
    sprintf(textbuf,"\n\rT0 Interrupt  : %u ms",T0PR);
6
    uart0Puts(textbuf);
7
}

Trotzdem würde ich gern die "professionelle Lösung" vorziehen. Beispiel 
wäre gut.

PS: Frage mich wieso printf beim gcc 10kb braucht, bei Microchip PICS 
schaffen die das mit 1,5kb und voller Funktionalität mit float.

von Stephan (Gast)


Angehängte Dateien:

Lesenswert?

Hi,

hier ein Beispiel.
Das war bei meinen Examples für AT91SAM7X dabei!

mfg

Stephan

von Christian J. (Gast)


Lesenswert?

Läuft ! :-)

Ich musste einen Unterstrich weglassen, warum weiss ich nicht, 
jedenfalls lüppt es.... die Nacht kann lang werden :-)

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.