diff --git a/celt b/celt
index d25dd2bff9f111fcc8d2de802c1cca337db27873..cb73e5ca62f93f530e65b244cf52f905a727d04d 160000
--- a/celt
+++ b/celt
@@ -1 +1 @@
-Subproject commit d25dd2bff9f111fcc8d2de802c1cca337db27873
+Subproject commit cb73e5ca62f93f530e65b244cf52f905a727d04d
diff --git a/src/opus_encoder.c b/src/opus_encoder.c
index 1872fe9afba21a06e3adaac3f7bbfd6c4048ac1e..cf0eee178308741763a8123851a1d1334afa764b 100644
--- a/src/opus_encoder.c
+++ b/src/opus_encoder.c
@@ -583,7 +583,10 @@ int opus_encoder_ctl(OpusEncoder *st, int request, ...)
         case OPUS_SET_PACKET_LOSS_PERC_REQUEST:
         {
             int value = va_arg(ap, int);
+            if (value < 0 || value > 100)
+                return OPUS_BAD_ARG;
             st->silk_mode.packetLossPercentage = value;
+            celt_encoder_ctl(st->celt_enc, CELT_SET_LOSS_PERC(value));
         }
         break;
         case OPUS_GET_PACKET_LOSS_PERC_REQUEST:
@@ -609,7 +612,7 @@ int opus_encoder_ctl(OpusEncoder *st, int request, ...)
         {
             int value = va_arg(ap, int);
             if (value>100 || value<0)
-                return OPUS_BAD_ARG;
+                goto bad_arg;
             st->voice_ratio = value;
         }
         break;
@@ -635,9 +638,11 @@ int opus_encoder_ctl(OpusEncoder *st, int request, ...)
             fprintf(stderr, "unknown opus_encoder_ctl() request: %d", request);
             break;
     }
-
     va_end(ap);
     return OPUS_OK;
+bad_arg:
+    va_end(ap);
+    return OPUS_BAD_ARG;
 }
 
 void opus_encoder_destroy(OpusEncoder *st)