Forum: Compiler & IDEs clangd als lsp-server für esp32-code: unknown target triple


von M. M. (anonusr)


Lesenswert?

Ich verwende in meinem Editor (emacs) clangd als language server, was 
grundsätzlich funktioniert.

Nun scheitere ich aber beim Editieren eines eps32-Projektes (C-Code mit 
idf). Auch meine ich, früher sei das gegangen, aber seit einiger Zeit 
(irgendein unbemerktes Update?) verweigert clangd nun den Dienst.

In den logs finde ich:

```
E[17:54:58.373] Could not build a preamble for file /xxx/xxx.c version 
0: CreateTargetInfo() return null
E[17:54:58.373]   error: unknown target triple 
'xtensa-esp32-unknown-elf'
E[17:54:58.374] Failed to prepare a compiler instance: unknown target 
triple 'xtensa-esp32-unknown-elf'
```

Und später immer `error: invalid AST`

Was ist die Sache mit dem "target triple", und wie gehe ich damit um?

Clangd wird wie folgt aufgerufen:

```
/usr/bin/clangd-19 
--query-driver=/home/xxx/.espressif/tools/xtensa-esp-elf/esp-14.2.0_2024 
1119/xtensa-esp-elf/bin/xtensa-esp32-elf-gcc  --log=verbose --pretty
```

von M. M. (anonusr)


Lesenswert?

Unterdessen bin ich etwas weiter:

Der Fehler tritt erst ab clangd 16 auf. Mit den Versionen 14 und 15 
funktioniert alles wie es soll.

Das Kommando unten funktioniert (von der Kommandozeile aus), nicht 
jedoch mit clangd-16:
1
clangd-15 --query-driver=/home/xxx/.espressif/tools/xtensa-esp-elf/esp-14.2.0_20241119/xtensa-esp-elf/bin/xtensa-esp32-elf-gcc --check=main/xxx.h --log=verbose

Ich verstehe aber nicht, ob das neue Verhalten korrekt ist oder ein Bug, 
und wie ich damit umgehen soll...

: Bearbeitet durch User
von Foka M. (foka)


Lesenswert?

Hi,

hatte vor kurzem das gleich Problem auch. Ich vermute es ist ein Bug 
und, wie ich es sehe, gibt es daufer auch schon ein patch:
https://github.com/llvm/llvm-project/pull/115798
... leider seit einem halben Jahr noch nicht gemerged.

clangd 15, oder sogar 14, ist auch sehr gut und tut seinen job. 
Zumindest konnte ich damit sehr gut weiter machen.
Vielleicht waer's auch ein workaround fuer Dich: einfach bei clangd-15 
bleiben bis neuer clang die Welt erblickt und den Patch hoffentlich 
integriert.

-Foka

von Harald K. (kirnbichler)


Lesenswert?

Man kann clang fragen, welche targets es unterstützt.

clang -print-targets

Du könntest in der Verzeichnishierarchie von clang/llvm mal nach einer 
Datei mit dem Namen "xtensa-esp32-unknown-elf.cfg" suchen.

Oder nach Dateien à la "xtensa-*.cfg"

Vergleiche das Ergebnis zwischen den verschiedenen clang-Versionen.

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.