/* * Copyright (C) 2016 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ANDROID_HARDWARE_BINDER_KERNEL_H #define ANDROID_HARDWARE_BINDER_KERNEL_H #include <linux/android/binder.h> /** * This file exists because the uapi kernel headers in bionic are built * from upstream kernel headers only, and the hwbinder kernel changes * haven't made it upstream yet. Therefore, the modifications to the * binder header are added locally in this file. */ enum { BINDER_TYPE_PTR = B_PACK_CHARS('p', 't', '*', B_TYPE_LARGE), BINDER_TYPE_FDA = B_PACK_CHARS('f', 'd', 'a', B_TYPE_LARGE), }; /* This header is used in all binder objects that are fixed * up by the kernel driver */ struct binder_object_header { __u32 type; }; struct binder_fd_object { struct binder_object_header hdr; /* FD objects used to be represented in flat_binder_object as well, * so we're using pads here to remain compatibile to existing userspace * clients. */ __u32 pad_flags; union { binder_uintptr_t pad_binder; __u32 fd; }; binder_uintptr_t cookie; }; /* A binder_buffer object represents an object that the * binder kernel driver copies verbatim to the target * address space. A buffer itself may be pointed to from * within another buffer, meaning that the pointer inside * that other buffer needs to be fixed up as well. This * can be done by specifying the parent buffer, and the * byte offset at which the pointer lives in that buffer. */ struct binder_buffer_object { struct binder_object_header hdr; __u32 flags; union { struct { binder_uintptr_t buffer; /* Pointer to buffer data */ binder_size_t length; /* Length of the buffer data */ }; struct { binder_size_t child; /* index of child in objects array */ binder_size_t child_offset; /* byte offset in child buffer */ }; }; binder_size_t parent; /* index of parent in objects array */ binder_size_t parent_offset; /* byte offset of pointer in parent buffer */ }; enum { BINDER_BUFFER_HAS_PARENT = 1U << 0, BINDER_BUFFER_REF = 1U << 1, }; /* A binder_fd_array object represents an array of file * descriptors embedded in a binder_buffer_object. The * kernel driver will fix up all file descriptors in * the parent buffer specified by parent and parent_offset */ struct binder_fd_array_object { struct binder_object_header hdr; __u32 _pad; /* hdr is 4 bytes, ensure 8-byte alignment of next fields */ binder_size_t num_fds; binder_size_t parent; /* index of parent in objects array */ binder_size_t parent_offset; /* offset of pointer in parent */ }; struct binder_transaction_data_sg { binder_transaction_data tr; /* regular transaction data */ binder_size_t buffers_size; /* number of bytes of SG buffers */ }; enum { BC_TRANSACTION_SG = _IOW('c', 17, struct binder_transaction_data_sg), BC_REPLY_SG = _IOW('c', 18, struct binder_transaction_data_sg), }; enum { FLAT_BINDER_FLAG_SCHEDPOLICY_MASK = 0x600, FLAT_BINDER_FLAG_SCHEDPOLICY_SHIFT = 9, }; #endif // ANDROID_HARDWARE_BINDER_KERNEL_H