0

FPU を持たない MIPS 24k コアを使用しています。QT を正常にクロスコンパイルしましたが、正常に動作します。しかし、 qatomic_mips.h で定義されている QBasicAtomicInt::testAndSetAcquire() に触れると、SIGSEGV が発生することがあります。

コードの本体にはインライン アセンブリ言語があります。私がそれを扱うのはこれが初めてです。そのため、最初に問題のある行を見つけようとしたときに、破壊されたレジスタのリストに言及している最後の行を指していました。

後で別のアプローチを取ったとき、以下で強調表示されている行で失敗したようです。_q_value の意味は何ですか?

inline bool QBasicAtomicInt::testAndSetAcquire(int expectedValue, int newValue)
{
register int result;
register int tempValue;
asm volatile(".set push\n"
             SET_MIPS2
             "0:\n"
             "ll %[result], %[_q_value]\n" //this line causes the SIGSEGV
             "xor %[result], %[result], %[expectedValue]\n"
             "bnez %[result], 0f\n"
             "nop\n"
             "move %[tempValue], %[newValue]\n"
             "sc %[tempValue], %[_q_value]\n"
             "beqz %[tempValue], 0b\n"
             "nop\n"
             "sync\n"
             "0:\n"
             ".set pop\n"
             : [result] "=&r" (result),
               [tempValue] "=&r" (tempValue),
               [_q_value] "+m" (_q_value)
             : [expectedValue] "r" (expectedValue),
               [newValue] "r" (newValue)
             : "cc", "memory"); 
return result == 0;
}

分解:

00207478 <_ZN20QEventDispatcherUNIX6wakeUpEv>:
207478: 3c1c001a    lui gp,0x1a
20747c: 279c99f8    addiu   gp,gp,-26120
207480: 0399e021    addu    gp,gp,t9
207484: 27bdffc8    addiu   sp,sp,-56
207488: afbf0030    sw  ra,48(sp)
20748c: afb3002c    sw  s3,44(sp)
207490: afb20028    sw  s2,40(sp)
207494: afb10024    sw  s1,36(sp)
207498: afb00020    sw  s0,32(sp)
20749c: afbc0010    sw  gp,16(sp)
2074a0: 8c860004    lw  a2,4(a0)
2074a4: 00001821    move    v1,zero
2074a8: 24020001    li  v0,1
2074ac: c0c40768    ll  a0,1896(a2) //this is the exact line
2074b0: 00832026    xor a0,a0,v1
2074b4: 14800008    bnez    a0,2074d8 <_ZN20QEventDispatcherUNIX6wakeUpEv+0x60>
2074b8: 00000000    nop
2074bc: 00000000    nop
2074c0: 00402821    move    a1,v0
2074c4: e0c50768    sc  a1,1896(a2)
2074c8: 10a0fff8    beqz    a1,2074ac <_ZN20QEventDispatcherUNIX6wakeUpEv+0x34>
2074cc: 00000000    nop
2074d0: 00000000    nop
2074d4: 0000000f    sync
2074d8: 14800012    bnez    a0,207524 <_ZN20QEventDispatcherUNIX6wakeUpEv+0xac>
2074dc: 27b30018    addiu   s3,sp,24
2074e0: a3a00018    sb  zero,24(sp)
2074e4: 8cd00058    lw  s0,88(a2)
2074e8: 2412ffff    li  s2,-1
2074ec: 24110004    li  s1,4
2074f0: 8f99cef0    lw  t9,-12560(gp)
2074f4: 02002021    move    a0,s0
2074f8: 02602821    move    a1,s3
2074fc: 0320f809    jalr    t9
207500: 24060001    li  a2,1
207504: 8fbc0010    lw  gp,16(sp)
207508: 14520006    bne v0,s2,207524    <_ZN20QEventDispatcherUNIX6wakeUpEv+0xac>
20750c: 8f99c864    lw  t9,-14236(gp)
207510: 0320f809    jalr    t9
207514: 00000000    nop
207518: 8c430000    lw  v1,0(v0)
20751c: 1071fff4    beq v1,s1,2074f0 <_ZN20QEventDispatcherUNIX6wakeUpEv+0x78>
207520: 8fbc0010    lw  gp,16(sp)
207524: 8fbf0030    lw  ra,48(sp)
207528: 8fb3002c    lw  s3,44(sp)
20752c: 8fb20028    lw  s2,40(sp)
207530: 8fb10024    lw  s1,36(sp)
207534: 8fb00020    lw  s0,32(sp)
207538: 03e00008    jr  ra
20753c: 27bd0038    addiu   sp,sp,56
4

1 に答える 1

1

MIPS CPU にはcondition codeレジスタ (x86(E/R)FLAGSレジスタと同等) がないため、レジスタを指定してコードをコンパイルすると、単純に無視される可能性があります。OTOH、そもそも使うべきじゃなかった。MIPS にとって特別な意味があるのだろうかと思います"cc"が、今のところ何も見つかりません。削除"cc"してみて、コードまたはその動作に変更があるかどうかを確認してください。

SIGSEGVコードで不適切なポインターが使用されているか、ポインターが適切に配置されていない (4 の倍数ではない) 可能性があります。

于 2013-04-05T05:44:50.067 に答える