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/android/binder.h>
9 
10 struct binder_state;
11 
12 struct binder_io
13 {
14     char *data;            /* pointer to read/write from */
15     binder_size_t *offs;   /* array of offsets */
16     size_t data_avail;     /* bytes available in data buffer */
17     size_t offs_avail;     /* entries available in offsets array */
18 
19     char *data0;           /* start of data buffer */
20     binder_size_t *offs0;  /* start of offsets buffer */
21     uint32_t flags;
22     uint32_t unused;
23 };
24 
25 struct binder_death {
26     void (*func)(struct binder_state *bs, void *ptr);
27     void *ptr;
28 };
29 
30 /* the one magic handle */
31 #define BINDER_SERVICE_MANAGER  0U
32 
33 #define SVC_MGR_NAME "android.os.IServiceManager"
34 
35 enum {
36     /* Must match definitions in IBinder.h and IServiceManager.h */
37     PING_TRANSACTION  = B_PACK_CHARS('_','P','N','G'),
38     SVC_MGR_GET_SERVICE = 1,
39     SVC_MGR_CHECK_SERVICE,
40     SVC_MGR_ADD_SERVICE,
41     SVC_MGR_LIST_SERVICES,
42 };
43 
44 typedef int (*binder_handler)(struct binder_state *bs,
45                               struct binder_transaction_data *txn,
46                               struct binder_io *msg,
47                               struct binder_io *reply);
48 
49 struct binder_state *binder_open(const char* driver, size_t mapsize);
50 void binder_close(struct binder_state *bs);
51 
52 /* initiate a blocking binder call
53  * - returns zero on success
54  */
55 int binder_call(struct binder_state *bs,
56                 struct binder_io *msg, struct binder_io *reply,
57                 uint32_t target, uint32_t code);
58 
59 /* release any state associate with the binder_io
60  * - call once any necessary data has been extracted from the
61  *   binder_io after binder_call() returns
62  * - can safely be called even if binder_call() fails
63  */
64 void binder_done(struct binder_state *bs,
65                  struct binder_io *msg, struct binder_io *reply);
66 
67 /* manipulate strong references */
68 void binder_acquire(struct binder_state *bs, uint32_t target);
69 void binder_release(struct binder_state *bs, uint32_t target);
70 
71 void binder_link_to_death(struct binder_state *bs, uint32_t target, struct binder_death *death);
72 
73 void binder_loop(struct binder_state *bs, binder_handler func);
74 
75 int binder_become_context_manager(struct binder_state *bs);
76 
77 /* allocate a binder_io, providing a stack-allocated working
78  * buffer, size of the working buffer, and how many object
79  * offset entries to reserve from the buffer
80  */
81 void bio_init(struct binder_io *bio, void *data,
82            size_t maxdata, size_t maxobjects);
83 
84 void bio_put_obj(struct binder_io *bio, void *ptr);
85 void bio_put_ref(struct binder_io *bio, uint32_t handle);
86 void bio_put_uint32(struct binder_io *bio, uint32_t n);
87 void bio_put_string16(struct binder_io *bio, const uint16_t *str);
88 void bio_put_string16_x(struct binder_io *bio, const char *_str);
89 
90 uint32_t bio_get_uint32(struct binder_io *bio);
91 uint16_t *bio_get_string16(struct binder_io *bio, size_t *sz);
92 uint32_t bio_get_ref(struct binder_io *bio);
93 
94 #endif
95