sk_dst_reset(ssk);
                        }
                        break;
+               case SO_INCOMING_CPU:
+                       WRITE_ONCE(ssk->sk_incoming_cpu, val);
+                       break;
                }
 
                subflow->setsockopt_seq = msk->setsockopt_seq;
        return 0;
 }
 
+static void mptcp_so_incoming_cpu(struct mptcp_sock *msk, int val)
+{
+       struct sock *sk = (struct sock *)msk;
+
+       WRITE_ONCE(sk->sk_incoming_cpu, val);
+
+       mptcp_sol_socket_sync_intval(msk, SO_INCOMING_CPU, val);
+}
+
 static int mptcp_setsockopt_sol_socket_int(struct mptcp_sock *msk, int optname,
                                           sockptr_t optval, unsigned int optlen)
 {
        case SO_RCVBUF:
        case SO_RCVBUFFORCE:
                return mptcp_sol_socket_intval(msk, optname, val);
+       case SO_INCOMING_CPU:
+               mptcp_so_incoming_cpu(msk, val);
+               return 0;
        }
 
        return -ENOPROTOOPT;
        case SO_RCVBUF:
        case SO_RCVBUFFORCE:
        case SO_MARK:
+       case SO_INCOMING_CPU:
                return mptcp_setsockopt_sol_socket_int(msk, optname, optval, optlen);
        case SO_LINGER:
                return mptcp_setsockopt_sol_socket_linger(msk, optval, optlen);