From 607f3bc55c2425c7e7d022961517793eb20f3b74 Mon Sep 17 00:00:00 2001 From: cinap_lenrek Date: Sat, 3 Sep 2016 17:01:56 +0200 Subject: 5l: format assembly constant right shift encoding 0 as >>32 --- sys/src/cmd/5l/list.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'sys/src') diff --git a/sys/src/cmd/5l/list.c b/sys/src/cmd/5l/list.c index 2422bcc0f..228cc1c56 100644 --- a/sys/src/cmd/5l/list.c +++ b/sys/src/cmd/5l/list.c @@ -143,8 +143,12 @@ Dconv(Fmt *fp) op = "<<>>->@>" + (((v>>5) & 3) << 1); if(v & (1<<4)) snprint(str, sizeof str, "R%ld%c%cR%ld", v&15, op[0], op[1], (v>>8)&15); - else - snprint(str, sizeof str, "R%ld%c%c%ld", v&15, op[0], op[1], (v>>7)&31); + else { + long sh = (v>>7)&31; + if(sh == 0 && (v & (3<<5)) != 0) + sh = 32; + snprint(str, sizeof str, "R%ld%c%c%ld", v&15, op[0], op[1], sh); + } if(a->reg != NREG) snprint(str+strlen(str), sizeof(str)-strlen(str), "(R%d)", a->reg); break; -- cgit v1.2.3