WARN_ON(!(stride <= VCHIQ_SLOT_SIZE));
 
        if (!(flags & QMFLAGS_NO_MUTEX_LOCK) &&
-               (mutex_lock_interruptible(&state->slot_mutex) != 0))
+               (mutex_lock_killable(&state->slot_mutex) != 0))
                return VCHIQ_RETRY;
 
        if (type == VCHIQ_MSG_DATA) {
                                return VCHIQ_RETRY;
                        if (service->closing)
                                return VCHIQ_ERROR;
-                       if (mutex_lock_interruptible(&state->slot_mutex) != 0)
+                       if (mutex_lock_killable(&state->slot_mutex) != 0)
                                return VCHIQ_RETRY;
                        if (service->srvstate != VCHIQ_SRVSTATE_OPEN) {
                                /* The service has been closed */
        local = state->local;
 
        if ((VCHIQ_MSG_TYPE(msgid) != VCHIQ_MSG_RESUME) &&
-               (mutex_lock_interruptible(&state->sync_mutex) != 0))
+               (mutex_lock_killable(&state->sync_mutex) != 0))
                return VCHIQ_RETRY;
 
        remote_event_wait(state, &local->sync_release);
                WARN_ON(!((int)(queue->local_insert - queue->process) > 0));
                WARN_ON(!((int)(queue->remote_insert - queue->process) > 0));
 
-               rc = mutex_lock_interruptible(&state->bulk_transfer_mutex);
+               rc = mutex_lock_killable(&state->bulk_transfer_mutex);
                if (rc != 0)
                        break;
 
                                int resolved = 0;
 
                                DEBUG_TRACE(PARSE_LINE);
-                               if (mutex_lock_interruptible(
+                               if (mutex_lock_killable(
                                        &service->bulk_mutex) != 0) {
                                        DEBUG_TRACE(PARSE_LINE);
                                        goto bail_not_ready;
                                        &service->bulk_rx : &service->bulk_tx;
 
                                DEBUG_TRACE(PARSE_LINE);
-                               if (mutex_lock_interruptible(
+                               if (mutex_lock_killable(
                                        &service->bulk_mutex) != 0) {
                                        DEBUG_TRACE(PARSE_LINE);
                                        goto bail_not_ready;
        VCHIQ_STATUS_T status;
 
        /* Abort any outstanding bulk transfers */
-       if (mutex_lock_interruptible(&service->bulk_mutex) != 0)
+       if (mutex_lock_killable(&service->bulk_mutex) != 0)
                return 0;
        abort_outstanding_bulks(service, &service->bulk_tx);
        abort_outstanding_bulks(service, &service->bulk_rx);
        queue = (dir == VCHIQ_BULK_TRANSMIT) ?
                &service->bulk_tx : &service->bulk_rx;
 
-       if (mutex_lock_interruptible(&service->bulk_mutex) != 0) {
+       if (mutex_lock_killable(&service->bulk_mutex) != 0) {
                status = VCHIQ_RETRY;
                goto error_exit;
        }
                                status = VCHIQ_RETRY;
                                goto error_exit;
                        }
-                       if (mutex_lock_interruptible(&service->bulk_mutex)
+                       if (mutex_lock_killable(&service->bulk_mutex)
                                != 0) {
                                status = VCHIQ_RETRY;
                                goto error_exit;
 
        /* The slot mutex must be held when the service is being closed, so
           claim it here to ensure that isn't happening */
-       if (mutex_lock_interruptible(&state->slot_mutex) != 0) {
+       if (mutex_lock_killable(&state->slot_mutex) != 0) {
                status = VCHIQ_RETRY;
                goto cancel_bulk_error_exit;
        }
 
        vchiq_log_trace(vchiq_core_log_level,
                "%s(%p) called", __func__, instance);
 
-       if (mutex_lock_interruptible(&state->mutex) != 0)
+       if (mutex_lock_killable(&state->mutex) != 0)
                return VCHIQ_RETRY;
 
        /* Remove all services */
        vchiq_log_trace(vchiq_core_log_level,
                "%s(%p) called", __func__, instance);
 
-       if (mutex_lock_interruptible(&state->mutex) != 0) {
+       if (mutex_lock_killable(&state->mutex) != 0) {
                vchiq_log_trace(vchiq_core_log_level,
                        "%s: call to mutex_lock failed", __func__);
                status = VCHIQ_RETRY;
 
 }
 #define down_interruptible down_interruptible_killable
 
-
-static inline int __must_check mutex_lock_interruptible_killable(struct mutex *lock)
-{
-       /* Allow interception of killable signals only. We don't want to be interrupted by harmless signals like SIGALRM */
-       int ret;
-       sigset_t blocked, oldset;
-       siginitsetinv(&blocked, SHUTDOWN_SIGS);
-       sigprocmask(SIG_SETMASK, &blocked, &oldset);
-       ret = mutex_lock_interruptible(lock);
-       sigprocmask(SIG_SETMASK, &oldset, NULL);
-       return ret;
-}
-#define mutex_lock_interruptible mutex_lock_interruptible_killable
-
 #endif