diff --git a/src/core/surface/call.c b/src/core/surface/call.c
index d15a3bcbade6ebf2d8b7038dbf3d1e45de1dc5e0..786535a579781ed22eaa27c66ab8c506a0b10d85 100644
--- a/src/core/surface/call.c
+++ b/src/core/surface/call.c
@@ -927,6 +927,7 @@ static int add_slice_to_message(grpc_call *call, gpr_slice slice) {
   }
   /* we have to be reading a message to know what to do here */
   if (!call->reading_message) {
+    gpr_slice_unref(slice);
     cancel_with_status(call, GRPC_STATUS_INVALID_ARGUMENT,
                        "Received payload data while not reading a message");
     return 0;