aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/include/asm/ps3gpu.h
diff options
context:
space:
mode:
authorGeert Uytterhoeven <Geert.Uytterhoeven@sonycom.com>2009-06-10 00:38:48 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2009-06-14 23:26:20 -0400
commitd3352c9f1e8e2f2989d9686c8aa8acb4842fe75e (patch)
treeea8a18d573a45f913d9e0669a17a0b39835e55ff /arch/powerpc/include/asm/ps3gpu.h
parent56ac72dba5d24a477d281b985797d5e62d3f5c2e (diff)
ps3fb/vram: Extract common GPU stuff into <asm/ps3gpu.h>
Signed-off-by: Geert Uytterhoeven <Geert.Uytterhoeven@sonycom.com> Cc: linux-fbdev-devel@lists.sourceforge.net Cc: Jim Paris <jim@jtan.com> Cc: Jens Axboe <axboe@kernel.dk> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/include/asm/ps3gpu.h')
-rw-r--r--arch/powerpc/include/asm/ps3gpu.h78
1 files changed, 78 insertions, 0 deletions
diff --git a/arch/powerpc/include/asm/ps3gpu.h b/arch/powerpc/include/asm/ps3gpu.h
new file mode 100644
index 000000000000..1037efae4a51
--- /dev/null
+++ b/arch/powerpc/include/asm/ps3gpu.h
@@ -0,0 +1,78 @@
1/*
2 * PS3 GPU declarations.
3 *
4 * Copyright 2009 Sony Corporation
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program.
17 * If not, see <http://www.gnu.org/licenses/>.
18 */
19
20#ifndef _ASM_POWERPC_PS3GPU_H
21#define _ASM_POWERPC_PS3GPU_H
22
23#include <linux/mutex.h>
24
25#include <asm/lv1call.h>
26
27
28#define L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_SYNC 0x101
29#define L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_FLIP 0x102
30
31#define L1GPU_CONTEXT_ATTRIBUTE_FB_SETUP 0x600
32#define L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT 0x601
33#define L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT_SYNC 0x602
34
35#define L1GPU_FB_BLIT_WAIT_FOR_COMPLETION (1ULL << 32)
36
37#define L1GPU_DISPLAY_SYNC_HSYNC 1
38#define L1GPU_DISPLAY_SYNC_VSYNC 2
39
40
41/* mutex synchronizing GPU accesses and video mode changes */
42extern struct mutex ps3_gpu_mutex;
43
44
45static inline int lv1_gpu_display_sync(u64 context_handle, u64 head,
46 u64 ddr_offset)
47{
48 return lv1_gpu_context_attribute(context_handle,
49 L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_SYNC,
50 head, ddr_offset, 0, 0);
51}
52
53static inline int lv1_gpu_display_flip(u64 context_handle, u64 head,
54 u64 ddr_offset)
55{
56 return lv1_gpu_context_attribute(context_handle,
57 L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_FLIP,
58 head, ddr_offset, 0, 0);
59}
60
61static inline int lv1_gpu_fb_setup(u64 context_handle, u64 xdr_lpar,
62 u64 xdr_size, u64 ioif_offset)
63{
64 return lv1_gpu_context_attribute(context_handle,
65 L1GPU_CONTEXT_ATTRIBUTE_FB_SETUP,
66 xdr_lpar, xdr_size, ioif_offset, 0);
67}
68
69static inline int lv1_gpu_fb_blit(u64 context_handle, u64 ddr_offset,
70 u64 ioif_offset, u64 sync_width, u64 pitch)
71{
72 return lv1_gpu_context_attribute(context_handle,
73 L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT,
74 ddr_offset, ioif_offset, sync_width,
75 pitch);
76}
77
78#endif /* _ASM_POWERPC_PS3GPU_H */