Index: /trunk/ippTools/share/Makefile.am
===================================================================
--- /trunk/ippTools/share/Makefile.am	(revision 14097)
+++ /trunk/ippTools/share/Makefile.am	(revision 14098)
@@ -29,4 +29,5 @@
 	regtool_processedexp.sql \
 	regtool_processedimfile.sql \
+	regtool_revertprocessedexp.sql \
 	regtool_revertprocessedimfile.sql \
 	stacktool_inputskyfile.sql \
Index: /trunk/ippTools/share/regtool_revertprocessedexp.sql
===================================================================
--- /trunk/ippTools/share/regtool_revertprocessedexp.sql	(revision 14098)
+++ /trunk/ippTools/share/regtool_revertprocessedexp.sql	(revision 14098)
@@ -0,0 +1,3 @@
+DELETE FROM rawExp
+WHERE
+    fault != 0
Index: /trunk/ippTools/src/regtool.c
===================================================================
--- /trunk/ippTools/src/regtool.c	(revision 14097)
+++ /trunk/ippTools/src/regtool.c	(revision 14098)
@@ -31,4 +31,5 @@
 #include "chiptool.h"
 
+// imfile
 static bool pendingimfileMode(pxConfig *config);
 static bool addprocessedimfileMode(pxConfig *config);
@@ -36,8 +37,9 @@
 static bool revertprocessedimfileMode(pxConfig *config);
 static bool updateprocessedimfileMode(pxConfig *config);
-
+// exp
 static bool pendingexpMode(pxConfig *config);
 static bool addprocessedexpMode(pxConfig *config);
 static bool processedexpMode(pxConfig *config);
+static bool revertprocessedexpMode(pxConfig *config);
 static bool updateprocessedexpMode(pxConfig *config);
 
@@ -70,4 +72,5 @@
 
     switch (config->mode) {
+        // imfile
         MODECASE(REGTOOL_MODE_PENDINGIMFILE,         pendingimfileMode);
         MODECASE(REGTOOL_MODE_ADDPROCESSEDIMFILE,    addprocessedimfileMode);
@@ -75,7 +78,9 @@
         MODECASE(REGTOOL_MODE_REVERTPROCESSEDIMFILE, revertprocessedimfileMode);
         MODECASE(REGTOOL_MODE_UPDATEPROCESSEDIMFILE, updateprocessedimfileMode);
+        // exp
         MODECASE(REGTOOL_MODE_PENDINGEXP,            pendingexpMode);
         MODECASE(REGTOOL_MODE_ADDPROCESSEDEXP,       addprocessedexpMode);
         MODECASE(REGTOOL_MODE_PROCESSEDEXP,          processedexpMode);
+        MODECASE(REGTOOL_MODE_REVERTPROCESSEDEXP,    revertprocessedexpMode);
         MODECASE(REGTOOL_MODE_UPDATEPROCESSEDEXP,    updateprocessedexpMode);
         default:
@@ -816,4 +821,35 @@
 
     psFree(output);
+
+    return true;
+}
+
+static bool revertprocessedexpMode(pxConfig *config)
+{
+    PS_ASSERT_PTR_NON_NULL(config, false);
+
+    psString query = pxDataGet("regtool_revertprocessedexp.sql");
+    if (!query) {
+        psError(PXTOOLS_ERR_DATA, false, "failed to retreive SQL statement");
+        return false;
+    }
+
+    if (config->where) {
+        psString whereClause = psDBGenerateWhereConditionSQL(config->where, "rawExp");
+        psStringAppend(&query, " AND %s", whereClause);
+        psFree(whereClause);
+    }
+
+    if (!p_psDBRunQuery(config->dbh, query)) {
+        psError(PS_ERR_UNKNOWN, false, "database error");
+        psFree(query);
+        return false;
+    }
+    psFree(query);
+
+    if (psDBAffectedRows(config->dbh) < 1) {
+        psError(PS_ERR_UNKNOWN, false, "should have affected atleast 1 row");
+        return false;
+    }
 
     return true;
Index: /trunk/ippTools/src/regtool.h
===================================================================
--- /trunk/ippTools/src/regtool.h	(revision 14097)
+++ /trunk/ippTools/src/regtool.h	(revision 14098)
@@ -33,4 +33,5 @@
     REGTOOL_MODE_ADDPROCESSEDEXP,
     REGTOOL_MODE_PROCESSEDEXP,
+    REGTOOL_MODE_REVERTPROCESSEDEXP,
     REGTOOL_MODE_UPDATEPROCESSEDEXP,
 } regtoolMode;
Index: /trunk/ippTools/src/regtoolConfig.c
===================================================================
--- /trunk/ippTools/src/regtoolConfig.c	(revision 14097)
+++ /trunk/ippTools/src/regtoolConfig.c	(revision 14098)
@@ -252,4 +252,11 @@
         "use the simple output format", false);
 
+    // -revertprocessedimfile
+    psMetadata *revertprocessedexpArgs = psMetadataAlloc();
+    psMetadataAddStr(revertprocessedexpArgs, PS_LIST_TAIL, "-exp_id",  0,
+            "search by exposure ID (required)", NULL);
+    psMetadataAddS16(revertprocessedexpArgs, PS_LIST_TAIL, "-code",  0,
+            "search by fault code", 0);
+
     // -updatedprocessedexp
     psMetadata *updatedprocessedexpArgs = psMetadataAlloc();
@@ -271,4 +278,5 @@
     PXTOOL_ADD_MODE("-addprocessedexp",         "",  REGTOOL_MODE_ADDPROCESSEDEXP, addprocessedexpArgs);
     PXTOOL_ADD_MODE("-processedexp",            "",     REGTOOL_MODE_PROCESSEDEXP, processedexpArgs);
+    PXTOOL_ADD_MODE("-revertprocessedexp",      "", REGTOOL_MODE_REVERTPROCESSEDEXP, revertprocessedexpArgs);
     PXTOOL_ADD_MODE("-updateprocessedexp",      "",  REGTOOL_MODE_UPDATEPROCESSEDEXP,      updatedprocessedexpArgs);
 
@@ -298,4 +306,17 @@
 }
 
+#define addWhereS16(name) \
+{ \
+    psS16 s16 = 0; \
+    bool status = false; \
+    if ((s16= psMetadataLookupS16(&status, config->args, "-" #name))) { \
+        if (!psMetadataAddS16(config->where, PS_LIST_TAIL, #name, 0, "==", s16)) { \
+            psError(PS_ERR_UNKNOWN, false, "failed to add item " #name); \
+            psFree(config); \
+            return NULL; \
+        } \
+    } \
+}
+
     // generate SQL where clause
     config->where = psMetadataAlloc();
@@ -320,4 +341,5 @@
     addWhereStr(tmp_class_id);
     addWhereStr(filter);
+    addWhereS16(code);
 
     if (config->where->list->n < 1) {
