binder.h revision 54b6cfa9a9e5b861a9930af873580d6dc20f773c
1/* Copyright 2008 The Android Open Source Project
2 */
3
4#ifndef _BINDER_H_
5#define _BINDER_H_
6
7#include <sys/ioctl.h>
8#include <linux/binder.h>
9
10struct binder_state;
11
12struct binder_object
13{
14    uint32_t type;
15    uint32_t flags;
16    void *pointer;
17    void *cookie;
18};
19
20struct binder_txn
21{
22    void *target;
23    void *cookie;
24    uint32_t code;
25    uint32_t flags;
26
27    uint32_t sender_pid;
28    uint32_t sender_euid;
29
30    uint32_t data_size;
31    uint32_t offs_size;
32    void *data;
33    void *offs;
34};
35
36struct binder_io
37{
38    char *data;            /* pointer to read/write from */
39    uint32_t *offs;        /* array of offsets */
40    uint32_t data_avail;   /* bytes available in data buffer */
41    uint32_t offs_avail;   /* entries available in offsets array */
42
43    char *data0;           /* start of data buffer */
44    uint32_t *offs0;       /* start of offsets buffer */
45    uint32_t flags;
46    uint32_t unused;
47};
48
49struct binder_death {
50    void (*func)(struct binder_state *bs, void *ptr);
51    void *ptr;
52};
53
54/* the one magic object */
55#define BINDER_SERVICE_MANAGER ((void*) 0)
56
57#define SVC_MGR_NAME "android.os.IServiceManager"
58
59enum {
60    SVC_MGR_GET_SERVICE = 1,
61    SVC_MGR_CHECK_SERVICE,
62    SVC_MGR_ADD_SERVICE,
63    SVC_MGR_LIST_SERVICES,
64};
65
66typedef int (*binder_handler)(struct binder_state *bs,
67                              struct binder_txn *txn,
68                              struct binder_io *msg,
69                              struct binder_io *reply);
70
71struct binder_state *binder_open(unsigned mapsize);
72void binder_close(struct binder_state *bs);
73
74/* initiate a blocking binder call
75 * - returns zero on success
76 */
77int binder_call(struct binder_state *bs,
78                struct binder_io *msg, struct binder_io *reply,
79                void *target, uint32_t code);
80
81/* release any state associate with the binder_io
82 * - call once any necessary data has been extracted from the
83 *   binder_io after binder_call() returns
84 * - can safely be called even if binder_call() fails
85 */
86void binder_done(struct binder_state *bs,
87                 struct binder_io *msg, struct binder_io *reply);
88
89/* manipulate strong references */
90void binder_acquire(struct binder_state *bs, void *ptr);
91void binder_release(struct binder_state *bs, void *ptr);
92
93void binder_link_to_death(struct binder_state *bs, void *ptr, struct binder_death *death);
94
95void binder_loop(struct binder_state *bs, binder_handler func);
96
97int binder_become_context_manager(struct binder_state *bs);
98
99/* allocate a binder_io, providing a stack-allocated working
100 * buffer, size of the working buffer, and how many object
101 * offset entries to reserve from the buffer
102 */
103void bio_init(struct binder_io *bio, void *data,
104           uint32_t maxdata, uint32_t maxobjects);
105
106void bio_destroy(struct binder_io *bio);
107
108void bio_put_obj(struct binder_io *bio, void *ptr);
109void bio_put_ref(struct binder_io *bio, void *ptr);
110void bio_put_uint32(struct binder_io *bio, uint32_t n);
111void bio_put_string16(struct binder_io *bio, const uint16_t *str);
112void bio_put_string16_x(struct binder_io *bio, const char *_str);
113
114uint32_t bio_get_uint32(struct binder_io *bio);
115uint16_t *bio_get_string16(struct binder_io *bio, uint32_t *sz);
116void *bio_get_obj(struct binder_io *bio);
117void *bio_get_ref(struct binder_io *bio);
118
119#endif
120