diff options
| author | Kuniyuki Iwashima <kuniyu@amazon.com> | 2025-01-16 14:34:39 +0900 | 
|---|---|---|
| committer | Jakub Kicinski <kuba@kernel.org> | 2025-01-20 11:27:41 -0800 | 
| commit | bace4b468049a558295a0f59460fcb51e28f8fde (patch) | |
| tree | 5376e681d675983b721d8d915e824d53b798a4e3 | |
| parent | 533643b091dd6e246d57caf81e6892fa9cbb1cc9 (diff) | |
af_unix: Set drop reason in unix_stream_read_skb().
unix_stream_read_skb() is called when BPF SOCKMAP reads some data
from a socket in the map.
SOCKMAP does not support MSG_OOB, and reading OOB results in a drop.
Let's set drop reasons respectively.
  * SOCKET_CLOSE  : the socket in SOCKMAP was close()d
  * UNIX_SKIP_OOB : OOB was read from the socket in SOCKMAP
Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
Link: https://patch.msgid.link/20250116053441.5758-7-kuniyu@amazon.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
| -rw-r--r-- | net/unix/af_unix.c | 4 | 
1 files changed, 2 insertions, 2 deletions
diff --git a/net/unix/af_unix.c b/net/unix/af_unix.c index e31fda1d319f..de4966e1b7ff 100644 --- a/net/unix/af_unix.c +++ b/net/unix/af_unix.c @@ -2724,7 +2724,7 @@ static int unix_stream_read_skb(struct sock *sk, skb_read_actor_t recv_actor)  		if (sock_flag(sk, SOCK_DEAD)) {  			unix_state_unlock(sk); -			kfree_skb(skb); +			kfree_skb_reason(skb, SKB_DROP_REASON_SOCKET_CLOSE);  			return -ECONNRESET;  		} @@ -2738,7 +2738,7 @@ static int unix_stream_read_skb(struct sock *sk, skb_read_actor_t recv_actor)  		unix_state_unlock(sk);  		if (drop) { -			kfree_skb(skb); +			kfree_skb_reason(skb, SKB_DROP_REASON_UNIX_SKIP_OOB);  			return -EAGAIN;  		}  	}  | 
