asm

アセンブリ解読 小休止

asm

これまで、4回に渡ってコンパイラ(gcc v5.4.0)の生成するアセンブリコードを解読してきた。これまでの内容は、以下のような感じになる。 その1: レジスタの使い方、関数の定石、初歩的な最適化 その2: 条件分岐、除算の最適化 その3: 除算の最適化と定数伝播…

アセンブリ解読 その4

asm

その2で宣言した通り、今回の対象はループだ。その2に続きが発生したので番号的には飛んでしまっているが、続きという点は変わらない。 しかしループとなると絶対にSIMDとループアンロールが絡んで面倒なことになる、と思っているので少し腰が重いが、最適化…

アセンブリ解読 その3

asm

前回長くなりすぎたので、追記分を分けておくことにした。 前回は簡易fizzbazzを逆アセンブルし、割り算の最適化に関して面白いものを見たのだった。 アセンブリ解読 その2 - in neuro その続きとして、moduloではなく普通の割り算はどうなるんだろう、と思…

アセンブリ解読 その2

asm

続いた。でもいい題材が思いつかなかったので、条件分岐とかがいいかなあと思いじゃあfizzbazzでいいか、となった。 その1はここにある。アセンブリ解読 その1 - in neuro 文字列を使うのが(アセンブリだと)アレなのでフラグを返すことにする。 #include <stdint.h> </stdint.h>…

アセンブリ解読 その1

asm

簡単なアセンブリを読めるようになりたい。理由はカッコいいから。というのは嘘で、どういう最適化が行われたかある程度わかるようになりたい。 だが、面白いコードが書けるようになるまでにアセンブリだと道のりが遠すぎるので、コンパイラに簡単なコードを…