Forum: Compiler & IDEs atof("123.34") will nicht ERROR?


von tobiTob (Gast)


Lesenswert?

Hallo,

nun ich habe eine Zeichenkette die ich im GGC mit atof in einen double 
Wert konvertieren will.

g_dou = atof(g_buftmp);


Wenn ich nun auf compilieren drücke kommt:

gcc plug-in: Error: Object file not found on expected location 
D:\Atmel\C\HelloWorld\default\HelloWorld.elf


Build started 25.7.2007 at 10:18:10
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/../../../../avr/lib/avr5\ 
libc.a(floatsisf.o):  In function `__floatsisf':
(.text.fplib+0x4): multiple definition of `__floatsisf'
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/avr5\libgcc.a(_si_to_sf.o 
):(.text+0x0):  first defined here
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/../../../../avr/lib/avr5\ 
libc.a(fixsfsi.o):  In function `__fixunssfsi':
(.text.fplib+0x0): multiple definition of `__fixsfsi'
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/avr5\libgcc.a(_sf_to_si.o 
):(.text+0x0):  first defined here
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/../../../../avr/lib/avr5\ 
libc.a(fixsfsi.o):  In function `__fixunssfsi':
(.text.fplib+0x0): multiple definition of `__fixunssfsi'
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/avr5\libgcc.a(_fixunssfsi 
.o):(.text+0x0):  first defined here
make: *** [HelloWorld.elf] Error 1
Build succeeded with 0 Warnings...


Ähm was ist daran falsch?

Gruß Tobi...

von Jörg W. (dl8dtl) (Moderator) Benutzerseite


Lesenswert?

Du brauchst -lm beim Linken.  Die sollte man eigentlich immer mit dabei
haben.

von tobiTob (Gast)


Lesenswert?

Hi Jörg,

ok jetzt compiliert er es durch, was macht das -lm ?

Gruß Tobi...

von Rufus Τ. F. (rufus) Benutzerseite


Lesenswert?

Es linkt mit libm.a, der Floatingpoint-Library.

von tobiTob (Gast)


Lesenswert?

Ja ok das hat er wohl auch gemacht aber das AVR Studio meint dann immer 
noch...

gcc plug-in: Error: Object file not found on expected location
D:\Atmel\C\HelloWorld\default\HelloWorld.elf

Habe mir erstmal damit geholfen das ich den double Wert "von Hand" 
berechne. Hmm nur interessant wäre es denoch warum er immer noch 
meckert...


MfG Tobi...

von Jörg W. (dl8dtl) (Moderator) Benutzerseite


Lesenswert?

> gcc plug-in: Error: Object file not found on expected location

Da hat AVR Studio nicht geschnallt, dass deine Compilierung fehlerhaft
war.  Guck mal in den Messages nach, was die Ursache ist.

von tobiTob (Gast)


Lesenswert?

das kommt bei den messages heraus...

Build started 26.7.2007 at 15:35:27
avr-gcc.exe -I"D:\Atmel\C\C-HelloWorld\."  -mmcu=atmega644 -Wall 
-gdwarf-2 -DF_CPU=18432000UL -Os -funsigned-char -funsigned-bitfields 
-MD -MP -MT C-HelloWorld.o -MF dep/C-HelloWorld.o.d  -c 
../C-HelloWorld.c

../C-HelloWorld.c: In function 'main':
avr-gcc.exe -mmcu=atmega644  -Wl,-section-start=.crcsection=0xeff0 
C-HelloWorld.o   -L"D:\Atmel\C\C-HelloWorld\."   -o C-HelloWorld.elf
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/../../../../avr/lib/avr5\ 
libc.a(floatsisf.o):  In function `__floatsisf':
(.text.fplib+0x4): multiple definition of `__floatsisf'
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/avr5\libgcc.a(_si_to_sf.o 
):(.text+0x0):  first defined here
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/../../../../avr/lib/avr5\ 
libc.a(fixsfsi.o):  In function `__fixunssfsi':
(.text.fplib+0x0): multiple definition of `__fixsfsi'
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/avr5\libgcc.a(_sf_to_si.o 
):(.text+0x0):  first defined here
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/../../../../avr/lib/avr5\ 
libc.a(fixsfsi.o):  In function `__fixunssfsi':
(.text.fplib+0x0): multiple definition of `__fixunssfsi'
c:/winavr-20070525rc2/bin/../lib/gcc/avr/4.1.2/avr5\libgcc.a(_fixunssfsi 
.o):(.text+0x0):  first defined here
make: *** [C-HelloWorld.elf] Error 1
Build succeeded with 8 Warnings...


Mir sagt das nix... irgendwas klemmt aber...
Gruß Tobi...

von Jörg W. (dl8dtl) (Moderator) Benutzerseite


Lesenswert?

Du hast schon wieder das -lm vergessen...

von tobiTob (Gast)


Lesenswert?

Hi Jörg,

war letzten Tage nicht daheim...

hmm also ich habe es mehrmals eingetragen keine Ahnung was ich falsch 
mache.

Ich habe nun "-lm" im Setup aufgenommen unter "all files" was sicher ok 
ist.

Es klappt noch immer nicht... :-(

avr-gcc.exe: -lm: linker input file unused because linking not done

Kannst du das mal Schritt für Schritt erklären was zu tun ist büdde

MfG Tobi...

von tobiTob (Gast)


Lesenswert?

Ok Lösung gefunden...

unter AVR Studio geht das alles etwas anders...

-lm nicht einfach bei linker optionen eintragen!
Auf der Seite libraries die libm.a datei auswählen und add object 
machen.

Dann klappt es hier auch... danke nochmal!

Gruß Tobi...

von Björn (Gast)


Lesenswert?

Ich hatte gerade das gleiche Problem.

Bevor noch einmal jemand versucht "Add Objects..." zu benutzen -
Benutzt lieber "Add Library...", dann klappt der Tip auch super!

Auf jeden Fall hat mir das Topic einen schweres Problem beseitigt, 
juuhuuuu

Schönen Samstag noch an Alle
Björn

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.