Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm/arm32 Recognize STREX* as store instructions



details:   https://anonhg.NetBSD.org/src/rev/eb53fb4ec2ab
branches:  trunk
changeset: 780602:eb53fb4ec2ab
user:      matt <matt%NetBSD.org@localhost>
date:      Mon Jul 30 22:54:33 2012 +0000

description:
Recognize STREX* as store instructions

diffstat:

 sys/arch/arm/arm32/fault.c |  7 ++++---
 1 files changed, 4 insertions(+), 3 deletions(-)

diffs (28 lines):

diff -r 5d804c6cf743 -r eb53fb4ec2ab sys/arch/arm/arm32/fault.c
--- a/sys/arch/arm/arm32/fault.c        Mon Jul 30 22:13:38 2012 +0000
+++ b/sys/arch/arm/arm32/fault.c        Mon Jul 30 22:54:33 2012 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: fault.c,v 1.80 2012/02/19 21:06:04 rmind Exp $ */
+/*     $NetBSD: fault.c,v 1.81 2012/07/30 22:54:33 matt Exp $  */
 
 /*
  * Copyright 2003 Wasabi Systems, Inc.
@@ -81,7 +81,7 @@
 #include "opt_kgdb.h"
 
 #include <sys/types.h>
-__KERNEL_RCSID(0, "$NetBSD: fault.c,v 1.80 2012/02/19 21:06:04 rmind Exp $");
+__KERNEL_RCSID(0, "$NetBSD: fault.c,v 1.81 2012/07/30 22:54:33 matt Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -427,7 +427,8 @@
 
                        if (((insn & 0x0c100000) == 0x04000000) || /* STR[B] */
                            ((insn & 0x0e1000b0) == 0x000000b0) || /* STR[HD]*/
-                           ((insn & 0x0a100000) == 0x08000000))   /* STM/CDT*/
+                           ((insn & 0x0a100000) == 0x08000000) || /* STM/CDT*/
+                           ((insn & 0x0f9000f0) == 0x01800090))   /* STREX[BDH] */
                                ftype = VM_PROT_WRITE; 
                        else if ((insn & 0x0fb00ff0) == 0x01000090)/* SWP */
                                ftype = VM_PROT_READ | VM_PROT_WRITE; 



Home | Main Index | Thread Index | Old Index