Allgemeine Probleme und Antworten
- max_10
- NI - VIP
- Beiträge: 163
- Registriert: Di 12. Apr 2016, 13:06
- Has thanked: 1 time
- Been thanked: 1 time
Re: Allgemeine Probleme und Antworten
nein es liegt daran, wie YYLTYPE geändert wird beim Kernel bauen, das entfernen der Zeile ist nicht der richtig weg,
es muss ein extern vor YYLTYPE yylloc; in scripts/dtc/dtc-parser.tab.c eingefügt werden.
es muss ein extern vor YYLTYPE yylloc; in scripts/dtc/dtc-parser.tab.c eingefügt werden.
- Kittybua1210!
- Beiträge: 186
- Registriert: Do 13. Jun 2019, 09:11
- Wohnort: Vienna
- Box: bre2ze4k+PC+Nintendo Switch
- Kontaktdaten:
Re: Allgemeine Probleme und Antworten
Wollte mich nochmals bedanken weil das mit der bin also das make neutrino-full-update ist echt top und Ruck zuck alles ! Super Tipp war das ! So einfach kann das Leben sein ! Lua API ist auch jetzt auf 1.96 und die version 2128 !Danke echt klasse von dir @vanhofen !vanhofen hat geschrieben: ↑So 24. Apr 2022, 21:34 Neuer Versuch.https://github.com/neutrino-images/ni-b ... 011472283a
P.s. nicht wundern bei der version nach Update schaut auf Lua API bzw Neutrino nicht Version es passt weil habe eine neue gebaut vorgestern da ist die Version größer als die alte aber Lua api etc älter so Beispiel nach Update bin:
Version : 4.10.95.112 hat API 1.95 und 2122 neutrino
Version : 4.10.89.111 hat API 1.96 und 2188 neutrino
Also nicht auf die Version Nummer schauen nach bin Update sondern auf das andere ! Wenn ich was falsches sage bitte ausbessern danke @vanhofen bin selber erst drauf gekommen da es mich gewundert hatte ! bin Datei ist also tip top !
- max_10
- NI - VIP
- Beiträge: 163
- Registriert: Di 12. Apr 2016, 13:06
- Has thanked: 1 time
- Been thanked: 1 time
Re: Allgemeine Probleme und Antworten
nun ist der fix wider kaputt
https://github.com/neutrino-images/ni-b ... fb4a1ee507
vu+ boxen fehlen.
https://github.com/neutrino-images/ni-b ... fb4a1ee507
vu+ boxen fehlen.
- vanhofen
- Administrator
- Beiträge: 2979
- Registriert: Di 5. Apr 2016, 00:05
- Has thanked: 18 times
- Been thanked: 37 times
Re: Allgemeine Probleme und Antworten
Die Solo4k ließ sich damit nicht kompilieren. Ich hatte den den Kanal voll und alle VUs ausgeschalten.
Bei dir geht das wohl bei der Solo4k?
Bei dir geht das wohl bei der Solo4k?
- max_10
- NI - VIP
- Beiträge: 163
- Registriert: Di 12. Apr 2016, 13:06
- Has thanked: 1 time
- Been thanked: 1 time
Re: Allgemeine Probleme und Antworten
Wenn es jetzt so bleibt, können alle die GCC Version 10 im System haben keine VU Box mehr bauen.
wenn die Kernel Version noch andere Einträge, mit YYLTYPE yylloc hat und sed das ändert kann das schon gegen den Wand laufen.
Mit der einen Änderung, wird dann auch gebaut, wenn im System GCC < 10 => 10 vorhanden ist.
Der Fehler lautet ja multiple defs yyloc, daher schrieb ich ja oben schon ändern in scripts/dtc/dtc-parser.tab.c,
wenn die Kernel Version noch andere Einträge, mit YYLTYPE yylloc hat und sed das ändert kann das schon gegen den Wand laufen.
Mit der einen Änderung, wird dann auch gebaut, wenn im System GCC < 10 => 10 vorhanden ist.
-
- Beiträge: 146
- Registriert: Mi 20. Okt 2021, 15:20
- Box: Amiko Alien Mini 3x, Bre2ze 4k
- Has thanked: 1 time
- Been thanked: 8 times
Re: Allgemeine Probleme und Antworten
<gebetsmühle>Wenn der system-Compiler oder im system installierte Pakete das Ergebnis einer Crosskompilation beeinträchtigen, dann ist das Buildsystem "broken beyond repair"</gebetsmühle>
Sag ich ja nur seit über 8 Jahren
Sag ich ja nur seit über 8 Jahren
- Miky
- NI - Team
- Beiträge: 1230
- Registriert: Di 5. Apr 2016, 17:17
- Box: Tank,Trinity,Neo 1,Neo2,Neo²,HD51
- Has thanked: 4 times
- Been thanked: 6 times
Re: Allgemeine Probleme und Antworten
Ach seife, vielleicht darf ich das nach glaube ich fast 20 Jahren Neutrino Zugehörigkeit einfach mal schreiben : warum schreibst du nicht, wie es zu fixen wäre? Und komm mir bitte nicht damit, dass du diese Boxen nicht hast, denn dann wäre dein Post eh nicht zielführend. Das begleitet mich nun schon so lange, ist eigentlich ein immer wiederkehrendes no go.
Boxen: Neo 1, Neo2 , Neo², Trinity, Tank, HD 51 alle SAT
Kein PN Support!
Kein PN Support!
-
- Beiträge: 146
- Registriert: Mi 20. Okt 2021, 15:20
- Box: Amiko Alien Mini 3x, Bre2ze 4k
- Has thanked: 1 time
- Been thanked: 8 times
Re: Allgemeine Probleme und Antworten
Die Kurze Antwort: man nimmt eine Buildumgebung, die dafür sorgt, daß das nicht passieren kann, weil sie mit selbsttests prüft ob sog. "host contamination" auftritt. z.B. openembedded.
Wenn man das nicht will, dann muss man das eigene Buildsystem so anpassen daß es das eben auch macht. Dazu gehört mindestens (aber bestimmt habe ich einige vergessen):
Ansonsten ist das Minimum was man machen sollte: Lösungen wie "ja, da musst du noch xyz-devel installieren" nicht zu akzeptieren, weil *immer* wenn ein crosscompileproblem auftritt, das durch "xyz-devel" gelöst wird, dann hat der buildjob an der falschen Stelle nach den xyz-devel Headern gesucht (oder xyz.pc, und wenn der von der falschen stelle gelesen hat, dann stehen da auch falsche sachen drin).
Beim Cross bauen ist es eben nicht egal wo der Header herkommt. Ich hab mal ein paar Tage nach einem mysteriösen Segfault gesucht, bis ich drauf gekommen bin daß der curl-header vom Host genommen wurde, von einer neueren Version war, wo sich eine Datenstruktur in der Größe geändert hatte. Ich sag mal so. Die Ursache zu finden ist für Fortgeschrittene
Ich hab, als ich noch die "falsche" Methode benutzt habe, öfters mal versucht, auf einem minimalsystem zu bauen. Also nur das installieren, was man zum crosstool bauen benötigt (und halt make etc). Wenn dann plötzlich sachen nicht zu bauen gehen, dann deutet das darauf hin, daß ein notwendiges Tool fehlt. Damals hatte ich dazu ein paar snapshots von minimalinstallierten VMs, heute würde ich vermutlich docker-Container dafür nehmen.
Wenn man das nicht will, dann muss man das eigene Buildsystem so anpassen daß es das eben auch macht. Dazu gehört mindestens (aber bestimmt habe ich einige vergessen):
- -nostdinc & co beim kompilieren nutzen, wo irgend möglich oder den crosscompiler gleich so bauen, daß der default-include-pfad irgendwo in /invalid oder so liegt
- alle tools wie pkg-config, autoconf, automake, cmake, ... in einer cross-variante bauen, daß sie eben nicht in den normalen system-Pfaden nach includes, configs, wasauchimmer schauen, sondern nur in den fürs crosscompiling vorgesehenen Pfaden
- output aller buildjobs mitloggen (verbose mode natürlich) und hinterher nachschauen ob nicht doch irgendwo im falschen Pfad "geschaut" wurde
Ansonsten ist das Minimum was man machen sollte: Lösungen wie "ja, da musst du noch xyz-devel installieren" nicht zu akzeptieren, weil *immer* wenn ein crosscompileproblem auftritt, das durch "xyz-devel" gelöst wird, dann hat der buildjob an der falschen Stelle nach den xyz-devel Headern gesucht (oder xyz.pc, und wenn der von der falschen stelle gelesen hat, dann stehen da auch falsche sachen drin).
Beim Cross bauen ist es eben nicht egal wo der Header herkommt. Ich hab mal ein paar Tage nach einem mysteriösen Segfault gesucht, bis ich drauf gekommen bin daß der curl-header vom Host genommen wurde, von einer neueren Version war, wo sich eine Datenstruktur in der Größe geändert hatte. Ich sag mal so. Die Ursache zu finden ist für Fortgeschrittene
Ich hab, als ich noch die "falsche" Methode benutzt habe, öfters mal versucht, auf einem minimalsystem zu bauen. Also nur das installieren, was man zum crosstool bauen benötigt (und halt make etc). Wenn dann plötzlich sachen nicht zu bauen gehen, dann deutet das darauf hin, daß ein notwendiges Tool fehlt. Damals hatte ich dazu ein paar snapshots von minimalinstallierten VMs, heute würde ich vermutlich docker-Container dafür nehmen.
- max_10
- NI - VIP
- Beiträge: 163
- Registriert: Di 12. Apr 2016, 13:06
- Has thanked: 1 time
- Been thanked: 1 time
Re: Allgemeine Probleme und Antworten
Der Hauptgrund warum der Fehler auftritt liegt aber auch an >= GCC 10
Selbst openembedded-alliance-core Patch die ganzen alten Kernel, damit dann dort durch gebaut werden kann.
ab Kernel 4.14 im April 2020 wurde dort auch die Einträge bearbeitet °Remove redundant YYLOC global declaration°.gcc 10 will default to -fno-common, which causes this error at link
time:
(.text+0x0): multiple definition of `yylloc'; dtc-lexer.lex.o (symbol from plugin):(.text+0x0): first defined here
This is because both dtc-lexer as well as dtc-parser define the same
global symbol yyloc. Before with -fcommon those were merged into one
defintion. The proper solution would be to to mark this as "extern".
Selbst openembedded-alliance-core Patch die ganzen alten Kernel, damit dann dort durch gebaut werden kann.
- vanhofen
- Administrator
- Beiträge: 2979
- Registriert: Di 5. Apr 2016, 00:05
- Has thanked: 18 times
- Been thanked: 37 times
Re: Allgemeine Probleme und Antworten
Jungs, die gleichen Links wurden doch schon mehrfach gepostet und auch im Buildsystem erfolglos getestet. Das konntet ihr doch alle mitverfolgen. Uns jetzt einfach nur kommentarlos immer wieder die gleichen URLs vor die Füße zu werfen, ist nicht sehr zielführend.
- TangoCash
- NI - VIP
- Beiträge: 461
- Registriert: Di 12. Apr 2016, 20:18
- Box: Mutant HD51
- Has thanked: 2 times
- Been thanked: 9 times
- Kontaktdaten:
Re: Allgemeine Probleme und Antworten
Na pack doch die entsprechenden Kernel-Patches dazu.
- Dateianhänge
-
- patches.zip
- (2.17 KiB) 145-mal heruntergeladen
Es gibt genau 10 Sorten von Leuten – nämlich diejenigen, die das binäre System verstehen, und diejenigen, die es nicht tun.
4x Mutant HD51
1x VU+ Ultimo 4k
1x Edision Mio+ 4k
1x Mutant HD60
4x Mutant HD51
1x VU+ Ultimo 4k
1x Edision Mio+ 4k
1x Mutant HD60
-
- NI - VIP
- Beiträge: 380
- Registriert: Di 12. Apr 2016, 04:53
- Has thanked: 10 times
- Been thanked: 11 times
- Kontaktdaten:
Re: Allgemeine Probleme und Antworten
Das dieser Patch schon gepostet wurde, muss ich übersehen haben. Wegen kommentarlos .... naja. Der Patch hat eine commit message die das Problem ja wirklich gut beschreibt. Das war halt was ich damals gemacht und was bei mir geholfen hatte. Die Zeile komplett aus scripts/dtc/dtc-lexer.l entfernen.vanhofen hat geschrieben: ↑Mi 27. Apr 2022, 08:35 Jungs, die gleichen Links wurden doch schon mehrfach gepostet und auch im Buildsystem erfolglos getestet. Das konntet ihr doch alle mitverfolgen. Uns jetzt einfach nur kommentarlos immer wieder die gleichen URLs vor die Füße zu werfen, ist nicht sehr zielführend.
"which means the declaration is completely redundant and can just be dropped."
Führen ja auch immer mehrere Wege nach Rom. Den Kernel mit '-fcommon' zu bauen könnte ja auch helfen.