Как использовать инструкцию TBB (Cortex-M3) с ассемблером GNU?

В разделе 3.10.4 общего руководства пользователя Arm (стр. 172) приведен пример использования TBB, но в этом примере используется сборщик Arm. Я хотел бы узнать, как использовать TBB с газом, но не могу понять, как это сделать. Как мне пересмотреть пример из руководства, чтобы реализовать оператор switch с газом вместо armasm?

ADR.W R0, BranchTable_Byte
TBB [R0, R1] ; R1 is the index, R0 is the base address of the
             ; branch table
Case1
; an instruction sequence follows
Case2
; an instruction sequence follows
Case3
; an instruction sequence follows
BranchTable_Byte
    DCB 0 ; Case1 offset calculation
    DCB ((Case2-Case1)/2) ; Case2 offset calculation
    DCB ((Case3-Case1)/2) ; Case3 offset calculation

Я новичок в использовании gas и не уверен, стоит ли мне определять таблицу ветвей в разделе.data в начале файла ассемблера или она должна идти после моего оператора switch в разделе.text.

1 ответ

Решение
.cpu cortex-m3
.thumb
.syntax unified

ADR.W R0, BranchTable_Byte
TBB [R0, R1] @; R1 is the index, R0 is the base address of the
             @; branch table
Case1:
@; an instruction sequence follows
    nop
Case2:
@; an instruction sequence follows
    nop
    nop
Case3:
@; an instruction sequence follows
    nop
    nop
    nop
BranchTable_Byte:
.byte 0 @; Case1 offset calculation
.byte ((Case2-Case1)/2) @; Case2 offset calculation
.byte ((Case3-Case1)/2) @; Case3 offset calculation

что-то вроде этого возможно. Нужны двоеточия на этикетках.; К сожалению, больше не комментарий @, повезло на математике лейбла.

Другие вопросы по тегам