diff --git a/unix/modtime.c b/unix/modtime.c
index 196b1506a505289aed2469afb00f4f3c2a7cff99..6843238cf3e09a8d72d2d03d44ffa8f92bf46785 100644
--- a/unix/modtime.c
+++ b/unix/modtime.c
@@ -121,7 +121,9 @@ STATIC mp_obj_t mod_time_sleep(mp_obj_t arg) {
     tv.tv_sec = ipart;
     int res;
     while (1) {
+        MP_THREAD_GIL_EXIT();
         res = sleep_select(0, NULL, NULL, NULL, &tv);
+        MP_THREAD_GIL_ENTER();
         #if MICROPY_SELECT_REMAINING_TIME
         // TODO: This assumes Linux behavior of modifying tv to the remaining
         // time.
@@ -139,20 +141,26 @@ STATIC mp_obj_t mod_time_sleep(mp_obj_t arg) {
     RAISE_ERRNO(res, errno);
 #else
     // TODO: Handle EINTR
+    MP_THREAD_GIL_EXIT();
     sleep(mp_obj_get_int(arg));
+    MP_THREAD_GIL_ENTER();
 #endif
     return mp_const_none;
 }
 STATIC MP_DEFINE_CONST_FUN_OBJ_1(mod_time_sleep_obj, mod_time_sleep);
 
 STATIC mp_obj_t mod_time_sleep_ms(mp_obj_t arg) {
+    MP_THREAD_GIL_EXIT();
     usleep(mp_obj_get_int(arg) * 1000);
+    MP_THREAD_GIL_ENTER();
     return mp_const_none;
 }
 STATIC MP_DEFINE_CONST_FUN_OBJ_1(mod_time_sleep_ms_obj, mod_time_sleep_ms);
 
 STATIC mp_obj_t mod_time_sleep_us(mp_obj_t arg) {
+    MP_THREAD_GIL_EXIT();
     usleep(mp_obj_get_int(arg));
+    MP_THREAD_GIL_ENTER();
     return mp_const_none;
 }
 STATIC MP_DEFINE_CONST_FUN_OBJ_1(mod_time_sleep_us_obj, mod_time_sleep_us);