Skip to content

Commit

Permalink
fix(bpf): fix bpf on aarch64
Browse files Browse the repository at this point in the history
Signed-off-by: Roberto Scolaro <[email protected]>
  • Loading branch information
therealbobo committed May 7, 2024
1 parent 12b4a2a commit dcf0488
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 0 deletions.
22 changes: 22 additions & 0 deletions driver/bpf/fillers.h
Original file line number Diff line number Diff line change
Expand Up @@ -578,29 +578,37 @@ static __always_inline int bpf_parse_readv_writev_bufs(struct filler_data *data,
int flags)
{
const struct iovec *iov;
#if defined(CONFIG_X86_64)
const struct compat_iovec *compat_iov;
#endif
int res = PPM_SUCCESS;
unsigned int copylen;
long size = 0;
int j;

#if defined(CONFIG_X86_64)
if (!bpf_in_ia32_syscall())
#endif
{
copylen = iovcnt * sizeof(struct iovec);
iov = (const struct iovec *)data->tmp_scratch;
}
#if defined(CONFIG_X86_64)
else
{
copylen = iovcnt * sizeof(struct compat_iovec);
compat_iov = (const struct compat_iovec *)data->tmp_scratch;
}
#endif

if (copylen > SCRATCH_SIZE_MAX)
{
return PPM_FAILURE_FRAME_SCRATCH_MAP_FULL;
}

#if defined(CONFIG_X86_64)
if (!bpf_in_ia32_syscall())
#endif
{
#ifdef BPF_FORBIDS_ZERO_ACCESS
if (copylen)
Expand All @@ -614,6 +622,7 @@ static __always_inline int bpf_parse_readv_writev_bufs(struct filler_data *data,
#endif
return PPM_FAILURE_INVALID_USER_MEMORY;
}
#if defined(CONFIG_X86_64)
else
{
#ifdef BPF_FORBIDS_ZERO_ACCESS
Expand All @@ -628,6 +637,7 @@ static __always_inline int bpf_parse_readv_writev_bufs(struct filler_data *data,
#endif
return PPM_FAILURE_INVALID_USER_MEMORY;
}
#endif


#pragma unroll
Expand All @@ -638,14 +648,18 @@ static __always_inline int bpf_parse_readv_writev_bufs(struct filler_data *data,
if (size == LONG_MAX)
break;

#if defined(CONFIG_X86_64)
if (!bpf_in_ia32_syscall())
#endif
{
size += iov[j].iov_len;
}
#if defined(CONFIG_X86_64)
else
{
size += compat_iov[j].iov_len;
}
#endif
}

if ((flags & PRB_FLAG_IS_WRITE) == 0)
Expand Down Expand Up @@ -674,25 +688,31 @@ static __always_inline int bpf_parse_readv_writev_bufs(struct filler_data *data,
if (off > SCRATCH_SIZE_HALF)
break;

#if defined(CONFIG_X86_64)
if (!bpf_in_ia32_syscall())
#endif
{
if (iov[j].iov_len <= remaining)
to_read = iov[j].iov_len;
else
to_read = remaining;
}
#if defined(CONFIG_X86_64)
else
{
if (compat_iov[j].iov_len <= remaining)
to_read = compat_iov[j].iov_len;
else
to_read = remaining;
}
#endif

if (to_read > SCRATCH_SIZE_HALF)
to_read = SCRATCH_SIZE_HALF;

#if defined(CONFIG_X86_64)
if (!bpf_in_ia32_syscall())
#endif
{
#ifdef BPF_FORBIDS_ZERO_ACCESS
if (to_read)
Expand All @@ -706,6 +726,7 @@ static __always_inline int bpf_parse_readv_writev_bufs(struct filler_data *data,
#endif
return PPM_FAILURE_INVALID_USER_MEMORY;
}
#if defined(CONFIG_X86_64)
else
{

Expand All @@ -722,6 +743,7 @@ static __always_inline int bpf_parse_readv_writev_bufs(struct filler_data *data,
return PPM_FAILURE_INVALID_USER_MEMORY;

}
#endif

remaining -= to_read;
off += to_read;
Expand Down
5 changes: 5 additions & 0 deletions driver/modern_bpf/helpers/store/auxmap_store_params.h
Original file line number Diff line number Diff line change
Expand Up @@ -627,6 +627,11 @@ static __always_inline void auxmap__store_sockaddr_param(struct auxiliary_map *a
start_reading_point = (unsigned long)sockaddr_un->sun_path;
}

// The addrlen is used has hard limit. So we should use add 1 for the `\0`
addrlen -= (FAMILY_SIZE + 1);
if(sockaddr_un->sun_path[addrlen-1] != '\0')
addrlen += 1;

/* Pack the sockaddr info:
* - socket family.
* - socket_unix_path (sun_path).
Expand Down

0 comments on commit dcf0488

Please sign in to comment.