diff --git a/opam b/opam
index bed88b46d0002fb0de4f308fa9a7e152e6718129..56c1cf67829ba451a6fe19747da8198749db0128 100644
--- a/opam
+++ b/opam
@@ -11,5 +11,5 @@ install: [make "install"]
 remove: ["rm" "-rf" "%{lib}%/coq/user-contrib/iris"]
 depends: [
   "coq" { (>= "8.7.1" & < "8.9~") | (= "dev") }
-  "coq-stdpp" { (= "dev.2018-04-21.1.49a03d40") | (= "dev") }
+  "coq-stdpp" { (= "dev.2018-04-27.1.32c8182a") | (= "dev") }
 ]
diff --git a/theories/heap_lang/lang.v b/theories/heap_lang/lang.v
index 39c6625fdc323eade1a7311b09c19a45056f1d16..e4e5dc55ab18da8a7d11477327a42b06b01f6ebb 100644
--- a/theories/heap_lang/lang.v
+++ b/theories/heap_lang/lang.v
@@ -351,10 +351,11 @@ Definition bin_op_eval_bool (op : bin_op) (b1 b2 : bool) : option base_lit :=
   end.
 
 Definition bin_op_eval (op : bin_op) (v1 v2 : val) : option val :=
+  if decide (op = EqOp) then Some $ LitV $ LitBool $ bool_decide (v1 = v2) else
   match v1, v2 with
   | LitV (LitInt n1), LitV (LitInt n2) => Some $ LitV $ bin_op_eval_int op n1 n2
   | LitV (LitBool b1), LitV (LitBool b2) => LitV <$> bin_op_eval_bool op b1 b2
-  | v1, v2 => guard (op = EqOp); Some $ LitV $ LitBool $ bool_decide (v1 = v2)
+  | _, _ => None
   end.
 
 Inductive head_step : expr → state → expr → state → list (expr) → Prop :=
diff --git a/theories/tests/heap_lang.v b/theories/tests/heap_lang.v
index 1e71aaba0c4cb639e4fbf81adf7cceee7b094286..62b74b5e0a6ce9ae1648016cec06161d8219d96e 100644
--- a/theories/tests/heap_lang.v
+++ b/theories/tests/heap_lang.v
@@ -71,6 +71,11 @@ Section LiftingTests.
     wp_load. wp_op. wp_faa. do 2 wp_load. wp_op. done.
   Qed.
 
+  Definition heap_e6 : val := λ: "v", "v" = "v".
+
+  Lemma heap_e6_spec (v : val) : (WP heap_e6 v {{ w, ⌜ w = #true ⌝ }})%I.
+  Proof. wp_lam. wp_op. by case_bool_decide. Qed.
+
   Definition FindPred : val :=
     rec: "pred" "x" "y" :=
       let: "yp" := "y" + #1 in