忍者ブログ

なんだか

知らないほうが幸せかもしれない

[PR]

×

[PR]上記の広告は3ヶ月以上新規記事投稿のないブログに表示されています。新しい記事を書く事で広告が消えます。

rx-elf-gcc(4.7.2)でbtst命令を使うようにしてみようという試み、その6

今回は、bit7の場合です。

0000 FB E2 00 00 00 00     mov.L   #_bar1, r14
0006 CC EE                 mov.B   [r14], r14
0008 61 0E                 cmp     #0, r14
000a FB E2 00 00 00 00     mov.L   #_bar, r14
0010 29 05                 blt     .L5
0012 F0 E7                 bset    #7, [r14].B
0014 02                    rts
                       .L5:
0015 F0 EF                 bclr    #7, [r14].B
0017 02                    rts

ちょっと違うやり方になります。

Failed to match this instruction:
(set (pc)
    (if_then_else (ge (subreg:SI (mem/c:QI (reg/f:SI 30) [0 bar1+0 S1 A8]) 0)
            (const_int 0 [0]))
        (label_ref 17)
        (pc)))


コンバインパターンはこうなっています。

(define_insn_and_split "*cbranchqi4_tst_ext_bitmem_msb"
  [(set (pc)
    (if_then_else
      (match_operator 2 "rx_zs_comparison_operator"
        [(subreg:SI
        (match_operand:QI 0 "rx_restricted_mem_operand" "Q") 0)
         (const_int 0)])
      (match_operand 1 "label_ref_operand" "")
      (pc)))]
  ""
  "#"
  "reload_completed"
  [(const_int 0)]
{
  rtx x;
  enum rtx_code code;

  x = gen_rtx_AND (SImode, operands[0], gen_int_mode (0x80, SImode));

  code = GET_CODE (operands[2]);
  if (code == GE) code = EQ;
  if (code == LT) code = NE;
  rx_split_cbranch (CC_ZSmode, code,
            x, const0_rtx, operands[1]);
  DONE;
})

rx.mdにこれを追加します。(*tstqi_bitmemをちょっと修正しています。)

コンパイルしたコードはこうなります。

0000 FB E2 00 00 00 00     mov.L   #_bar1, r14
0006 F4 E7                 btst    #7, [r14].B
0008 FB E2 00 00 00 00     mov.L   #_bar, r14
000e 1C                    bne     .L5
000f F0 E7                 bset    #7, [r14].B
0011 02                    rts
                       .L5:
0012 F0 EF                 bclr    #7, [r14].B
0014 02                    rts


btst-rx.patch  まとめたpatch

拍手[0回]

PR

コメント

お名前
タイトル
文字色
メールアドレス
URL
コメント
パスワード Vodafone絵文字 i-mode絵文字 Ezweb絵文字

カレンダー

03 2024/04 05
S M T W T F S
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30

フリーエリア

最新CM

最新記事

(07/27)
(03/27)
(03/26)
(03/23)
(03/22)
(03/19)
(03/18)
(03/18)
(03/15)
(03/14)
(03/13)
(03/12)
(03/11)
(03/11)
(03/08)
(03/08)
(03/06)
(03/05)
(03/02)
(03/01)
(02/28)
(02/27)
(02/24)
(02/23)
(02/22)

プロフィール

HN:
kenrou
性別:
非公開

バーコード

ブログ内検索

最古記事

(12/15)
(12/16)
(12/17)
(12/18)
(12/19)
(12/20)
(12/21)
(12/22)
(12/23)
(12/24)
(12/25)
(12/26)
(12/27)
(12/28)
(12/29)
(12/30)
(12/31)
(01/01)
(01/02)
(01/21)
(01/22)
(01/23)
(01/24)
(01/24)
(01/28)

P R

忍者アナライズ

コガネモチ

忍者カウンター

カレンダー

03 2024/04 05
S M T W T F S
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30