From 02131c7ff660a5ca08147899429e6e7780d737aa Mon Sep 17 00:00:00 2001 From: Mike Frysinger Date: Sat, 28 Mar 2015 14:55:11 -0400 Subject: [PATCH] sim: sh: fix broken handling in DSR reg A missing */ caused a case statement to be incorrect masked out which also hide an error where the wrong value was being checked. Fix both. --- sim/sh/ChangeLog | 4 ++++ sim/sh/gencode.c | 4 ++-- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/sim/sh/ChangeLog b/sim/sh/ChangeLog index 3e0fff1515..46b8e530f1 100644 --- a/sim/sh/ChangeLog +++ b/sim/sh/ChangeLog @@ -1,3 +1,7 @@ +2015-03-28 Mike Frysinger + + * gencode.c (ppi_gensim): Add missing */. Change case 4 to case 5. + 2015-03-28 Mike Frysinger * Makefile.in (gencode): Add $(BUILD_CFLAGS), $(BUILD_LDFLAGS), diff --git a/sim/sh/gencode.c b/sim/sh/gencode.c index 0fb1b87c24..bcaeb6c33a 100644 --- a/sim/sh/gencode.c +++ b/sim/sh/gencode.c @@ -3359,11 +3359,11 @@ ppi_gensim (void) printf (" DSR |= res_grd >> 7 & 1;\n"); printf (" case 2: /* Zero Value Mode */\n"); printf (" DSR |= DSR >> 6 & 1;\n"); - printf (" case 3: /* Overflow mode\n"); + printf (" case 3: /* Overflow mode */\n"); printf (" DSR |= overflow >> 4;\n"); printf (" case 4: /* Signed Greater Than Mode */\n"); printf (" DSR |= DSR >> 7 & 1;\n"); - printf (" case 4: /* Signed Greater Than Or Equal Mode */\n"); + printf (" case 5: /* Signed Greater Than Or Equal Mode */\n"); printf (" DSR |= greater_equal >> 7;\n"); printf (" }\n"); printf (" assign_z:\n");