diff options
author | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-03-19 04:47:30 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2013-03-19 04:47:30 -0400 |
commit | 0d4a42f6bd298e826620585e766a154ab460617a (patch) | |
tree | 406d8f7778691d858dbe3e48e4bbb10e99c0a58a /include/linux/async.h | |
parent | d62b4892f3d9f7dd2002e5309be10719d6805b0f (diff) | |
parent | a937536b868b8369b98967929045f1df54234323 (diff) |
Merge tag 'v3.9-rc3' into drm-intel-next-queued
Backmerge so that I can merge Imre Deak's coalesced sg entries fixes,
which depend upon the new for_each_sg_page introduce in
commit a321e91b6d73ed011ffceed384c40d2785cf723b
Author: Imre Deak <imre.deak@intel.com>
Date: Wed Feb 27 17:02:56 2013 -0800
lib/scatterlist: add simple page iterator
The merge itself is just two trivial conflicts:
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'include/linux/async.h')
-rw-r--r-- | include/linux/async.h | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/include/linux/async.h b/include/linux/async.h index 7a24fe9b44b4..a2e3f18b2ad6 100644 --- a/include/linux/async.h +++ b/include/linux/async.h | |||
@@ -19,8 +19,7 @@ typedef u64 async_cookie_t; | |||
19 | typedef void (async_func_ptr) (void *data, async_cookie_t cookie); | 19 | typedef void (async_func_ptr) (void *data, async_cookie_t cookie); |
20 | struct async_domain { | 20 | struct async_domain { |
21 | struct list_head node; | 21 | struct list_head node; |
22 | struct list_head domain; | 22 | struct list_head pending; |
23 | int count; | ||
24 | unsigned registered:1; | 23 | unsigned registered:1; |
25 | }; | 24 | }; |
26 | 25 | ||
@@ -29,8 +28,7 @@ struct async_domain { | |||
29 | */ | 28 | */ |
30 | #define ASYNC_DOMAIN(_name) \ | 29 | #define ASYNC_DOMAIN(_name) \ |
31 | struct async_domain _name = { .node = LIST_HEAD_INIT(_name.node), \ | 30 | struct async_domain _name = { .node = LIST_HEAD_INIT(_name.node), \ |
32 | .domain = LIST_HEAD_INIT(_name.domain), \ | 31 | .pending = LIST_HEAD_INIT(_name.pending), \ |
33 | .count = 0, \ | ||
34 | .registered = 1 } | 32 | .registered = 1 } |
35 | 33 | ||
36 | /* | 34 | /* |
@@ -39,8 +37,7 @@ struct async_domain { | |||
39 | */ | 37 | */ |
40 | #define ASYNC_DOMAIN_EXCLUSIVE(_name) \ | 38 | #define ASYNC_DOMAIN_EXCLUSIVE(_name) \ |
41 | struct async_domain _name = { .node = LIST_HEAD_INIT(_name.node), \ | 39 | struct async_domain _name = { .node = LIST_HEAD_INIT(_name.node), \ |
42 | .domain = LIST_HEAD_INIT(_name.domain), \ | 40 | .pending = LIST_HEAD_INIT(_name.pending), \ |
43 | .count = 0, \ | ||
44 | .registered = 0 } | 41 | .registered = 0 } |
45 | 42 | ||
46 | extern async_cookie_t async_schedule(async_func_ptr *ptr, void *data); | 43 | extern async_cookie_t async_schedule(async_func_ptr *ptr, void *data); |
@@ -52,4 +49,5 @@ extern void async_synchronize_full_domain(struct async_domain *domain); | |||
52 | extern void async_synchronize_cookie(async_cookie_t cookie); | 49 | extern void async_synchronize_cookie(async_cookie_t cookie); |
53 | extern void async_synchronize_cookie_domain(async_cookie_t cookie, | 50 | extern void async_synchronize_cookie_domain(async_cookie_t cookie, |
54 | struct async_domain *domain); | 51 | struct async_domain *domain); |
52 | extern bool current_is_async(void); | ||
55 | #endif | 53 | #endif |