mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-10 12:57:06 +09:00
staging: android: binder: Add align_helper() macro
This patch adds align_helper() macro that will be used for enforcing the desired alignment on 64bit systems where the alignment will differ depending on the userspace used (32bit /64bit). This patch is a temporary patch that will be extended with 32bit compat handling. Signed-off-by: Serban Constantinescu <serban.constantinescu@arm.com> Signed-off-by: John Stultz <john.stultz@linaro.org>
This commit is contained in:
committed by
John Stultz
parent
d1b83dd27f
commit
a4cffaa5e8
@@ -141,6 +141,8 @@ module_param_call(stop_on_user_error, binder_set_stop_on_user_error,
|
||||
binder_stop_on_user_error = 2; \
|
||||
} while (0)
|
||||
|
||||
#define align_helper(ptr) ALIGN(ptr, sizeof(void *))
|
||||
|
||||
enum binder_stat_types {
|
||||
BINDER_STAT_PROC,
|
||||
BINDER_STAT_THREAD,
|
||||
@@ -1240,7 +1242,7 @@ static void binder_transaction_buffer_release(struct binder_proc *proc,
|
||||
if (buffer->target_node)
|
||||
binder_dec_node(buffer->target_node, 1, 0);
|
||||
|
||||
offp = (size_t *)(buffer->data + ALIGN(buffer->data_size, sizeof(void *)));
|
||||
offp = (size_t *)(buffer->data + align_helper(buffer->data_size));
|
||||
if (failed_at)
|
||||
off_end = failed_at;
|
||||
else
|
||||
@@ -1477,7 +1479,7 @@ static void binder_transaction(struct binder_proc *proc,
|
||||
if (target_node)
|
||||
binder_inc_node(target_node, 1, 0, NULL);
|
||||
|
||||
offp = (size_t *)(t->buffer->data + ALIGN(tr->data_size, sizeof(void *)));
|
||||
offp = (size_t *)(t->buffer->data + align_helper(tr->data_size));
|
||||
|
||||
if (copy_from_user(t->buffer->data, tr->data.ptr.buffer, tr->data_size)) {
|
||||
binder_user_error("%d:%d got transaction with invalid data ptr\n",
|
||||
@@ -2396,8 +2398,7 @@ retry:
|
||||
tr.data.ptr.buffer = (void *)t->buffer->data +
|
||||
proc->user_buffer_offset;
|
||||
tr.data.ptr.offsets = tr.data.ptr.buffer +
|
||||
ALIGN(t->buffer->data_size,
|
||||
sizeof(void *));
|
||||
align_helper(t->buffer->data_size);
|
||||
|
||||
if (binder_copy_to_user(cmd, &tr, &ptr, sizeof(struct binder_transaction_data)))
|
||||
return -EFAULT;
|
||||
|
||||
Reference in New Issue
Block a user