Arhn - архитектура программирования

Golang Interpret gdb SIGILL, Недопустимая инструкция

Я написал небольшую программу для запуска на 32-битном маршрутизаторе MIPS. Я могу запустить базовую программу hello world на маршрутизаторе, используя цепочку инструментов go build.

env GOOS=linux GOARCH=mips GOMIPS=softfloat go build -a

Программа, которую я пытаюсь скомпилировать, использует библиотеку go-ethereum и выдает следующую ошибку при попытке сборки

go build github.com/ethereum/go-ethereum/crypto/secp256k1: build constraints exclude all Go files in ~/go/src/github.com/ethereum/go-ethereum/crypto/secp256k1

Я нашел инструмент кросс-компиляции xgo и успешно создал бинарный файл с помощью этого инструмента (https://github.com/karalabe/xgo). Когда я пытаюсь запустить двоичный файл, я получаю следующее «Программа завершена сигналом SIGILL, недопустимая инструкция». Мне удалось получить дамп ядра из файла, но у меня нет большого опыта работы с GDB.

Program terminated with signal SIGILL, Illegal instruction.
#0  0x008274a8 in __sigsetjmp_aux () 

Запустив компоновку asm, я получаю следующее:

    0x8274a4 <__sigsetjmp_aux+4>    addiu  gp,gp,-19312                                                                                                                          │
  >│0x8274a8 <__sigsetjmp_aux+8>    sdc1   $f20,56(a0)                                                                                                                           │
   │0x8274ac <__sigsetjmp_aux+12>   sdc1   $f22,64(a0)   

Я не уверен, как интерпретировать это, любая помощь будет высоко оценена.

Вот вывод cat /proc/cpuinfo :

system type     : Qualcomm Atheros QCA9533 ver 2 rev 0
machine         : GL.iNet GL-AR750
processor       : 0
cpu model       : MIPS 24Kc V7.4
BogoMIPS        : 432.53
wait instruction    : yes
microsecond timers  : yes
tlb_entries     : 16
extra interrupt vector  : yes
hardware watchpoint : yes, count: 4, address/irw mask: [0x0ffc, 0x0ffc, 0x0ffb, 0x0ffb]
isa         : mips1 mips2 mips32r1 mips32r2
ASEs implemented    : mips16
shadow register sets    : 1
kscratch registers  : 0
package         : 0
core            : 0
VCED exceptions     : not available
VCEI exceptions     : not available

и вывод файла util в бинарнике:

ELF 32-bit MSB executable, MIPS, MIPS32 rel2 version 1, statically linked, for GNU/Linux 3.2.0, BuildID[sha1]=83c74323a279af9cba50869671ef03d5ad497db8, not stripped

Я потратил довольно много времени, пытаясь запустить эту программу, даже развил инструмент xgo, чтобы он мог принимать параметр softfloat. Любая помощь или направление по этой проблеме будет принята с благодарностью, спасибо.


Ответы:


1

Я не уверен, как это интерпретировать

Google для «MIPS sdc1» показывает, что это инструкция с плавающей запятой «Сохранить двойное слово из сопроцессора-1».

Предположение: ваша встроенная система не имеет сопроцессора с плавающей запятой?

Вам, вероятно, потребуется добавить -msoft-float к вашей команде xgo и пересобрать.

Обновление:

крашится на том же вызове sdc1, регистры те же $f20,56(a0).

Да, но в той же функции (__sigsetjmp_aux) или в какой-то другой?

Вот вызов, который я создаю с помощью xgo: xgo --go=1.12 --targets=linux/mips --ldflags '-extldflags "-static -msoft-float"' ~/path/to/project

Похоже, подпрограмма __sigsetjmp_aux исходит из GLIBC, которая не создана xgo.

И версия GLIBC, которую вы используете, была собрана без -msoft-float, так что вы по-прежнему компонуете код, который ожидает аппаратную плавающую точку, которой не хватает вашей системе.

Шаг 1: проверьте, откуда берется __sigsetjmp_aux. Для этого вам нужно передать -y __sigsetjmp_aux компоновщику. Возможно, --ldflags '-extldflags "-static -msoft-float -Wl,-y,__sigsetjmp_aux"' сделает это.

Вы должны увидеть что-то похожее на это:

gcc t.o -Wl,-y,setjmp -static
t.o: reference to setjmp
/usr/lib/gcc/x86_64-linux-gnu/7/../../../x86_64-linux-gnu/libc.a(bsd-setjmp.o): definition of setjmp

Предполагая, что ваше определение __sigsetjmp_aux исходит из libc.a, вам нужно перестроить его с -msoft-float в CFLAGS.

Примечание: передача -msoft-float компоновщику неверна и не даст никакого эффекта — это флаг компилятора.

11.05.2019
  • Спасибо за комментарий, мне не удалось найти документацию по «msoft-float» в отношении xgo. Могу ли я передать это в ldflags ? Вот моя команда сборки xgo --targets=linux/mips --ldflags '-extldflags -static' ./path/to/project . Спасибо! 13.05.2019
  • Я добавил -msoft-float в ldflags и столкнулся с похожей проблемой. Есть ли где-то, что я мог пропустить? 14.05.2019
  • @MattLock столкнулся с похожей проблемой -- насколько похоже? Авария теперь в другой рутине? Это другая процедура из библиотеки? Эта библиотека тоже построена с помощью -msoft-float ? 14.05.2019
  • он падает при том же вызове sdc1, регистры те же $f20,56(a0). Вот вызов, который я создаю с помощью xgo: xgo --go=1.12 --targets=linux/mips --ldflags '-extldflags -static -msoft-float' ~/path/to/project Спасибо! 14.05.2019
  • T Ваши подозрения были верны, вызов пришел из libc.a: /usr/lib/gcc-cross/mips-linux-gnu/5/../../../../mips-linux-gnu/lib /../lib/libc.a(setjmp_aux.o): определение __sigsetjmp_aux Я продвинулся дальше в этом процессе, теперь я думаю, что я передаю CFLAGS. Нужно ли также передавать -msoft-float в CGO_FLAGS? передача флагов cgo: /usr/mips-linux-gnu/include/gnu/stubs.h:8:33: фатальная ошибка: gnu/stubs-o32_soft.h: такого файла или каталога нет. Передача libc6-dev_2.28-10_mips.deb в качестве аргумента deps для xgo также вызывает эту ошибку. Спасибо за вашу помощь. 14.05.2019
  • @MattLock Боюсь, я мало что знаю о xgo. Вероятно, вам следует принять этот ответ (исходная проблема хорошо понятна) и задать другой: как мне создать небольшую программу Go для MIPS без аппаратного FP? Мне также неясно, удалось ли вам перестроить GLIBC или найти существующую сборку с плавающей запятой. Это обязательно, прежде чем вы сможете двигаться дальше. 14.05.2019
  • Для большего контекста я изменил xgo build.sh (github.com/karalabe/xgo/blob/master/docker/base/build.sh) для включения следующих тегов в строке 414 + 415: CC=mips-linux-gnu-gcc-5 CXX= mips-linux-gnu-g++-5 GOOS=linux GOARCH=mips GOMIPS=softfloat CGO_ENABLED=1 CFLAGS=-msoft-float Я добавил GOMIPS=softfloat (был там с тех пор, как я опубликовал это) и совсем недавно параметр CFLAGS. Редактировать: я не видел вашего продолжения, спасибо за всю вашу помощь. Я опубликую другой вопрос. 14.05.2019
  • Давайте продолжим это обсуждение в чате. 14.05.2019
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..