diff options
-rw-r--r-- | arch/powerpc/include/asm/ps3.h | 3 | ||||
-rw-r--r-- | arch/powerpc/include/asm/ps3gpu.h | 78 | ||||
-rw-r--r-- | arch/powerpc/platforms/ps3/setup.c | 1 | ||||
-rw-r--r-- | drivers/block/ps3vram.c | 21 | ||||
-rw-r--r-- | drivers/ps3/ps3av_cmd.c | 3 | ||||
-rw-r--r-- | drivers/video/ps3fb.c | 72 |
6 files changed, 110 insertions, 68 deletions
diff --git a/arch/powerpc/include/asm/ps3.h b/arch/powerpc/include/asm/ps3.h index cdb6fd814de8..b9e4987986dd 100644 --- a/arch/powerpc/include/asm/ps3.h +++ b/arch/powerpc/include/asm/ps3.h | |||
@@ -520,7 +520,4 @@ void ps3_sync_irq(int node); | |||
520 | u32 ps3_get_hw_thread_id(int cpu); | 520 | u32 ps3_get_hw_thread_id(int cpu); |
521 | u64 ps3_get_spe_id(void *arg); | 521 | u64 ps3_get_spe_id(void *arg); |
522 | 522 | ||
523 | /* mutex synchronizing GPU accesses and video mode changes */ | ||
524 | extern struct mutex ps3_gpu_mutex; | ||
525 | |||
526 | #endif | 523 | #endif |
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 */ | ||
42 | extern struct mutex ps3_gpu_mutex; | ||
43 | |||
44 | |||
45 | static 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 | |||
53 | static 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 | |||
61 | static 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 | |||
69 | static 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 */ | ||
diff --git a/arch/powerpc/platforms/ps3/setup.c b/arch/powerpc/platforms/ps3/setup.c index 1a7b5ae0c83e..149bea2ce583 100644 --- a/arch/powerpc/platforms/ps3/setup.c +++ b/arch/powerpc/platforms/ps3/setup.c | |||
@@ -32,6 +32,7 @@ | |||
32 | #include <asm/udbg.h> | 32 | #include <asm/udbg.h> |
33 | #include <asm/prom.h> | 33 | #include <asm/prom.h> |
34 | #include <asm/lv1call.h> | 34 | #include <asm/lv1call.h> |
35 | #include <asm/ps3gpu.h> | ||
35 | 36 | ||
36 | #include "platform.h" | 37 | #include "platform.h" |
37 | 38 | ||
diff --git a/drivers/block/ps3vram.c b/drivers/block/ps3vram.c index 83c14533aea5..2c2ea9cb207b 100644 --- a/drivers/block/ps3vram.c +++ b/drivers/block/ps3vram.c | |||
@@ -17,6 +17,7 @@ | |||
17 | #include <asm/iommu.h> | 17 | #include <asm/iommu.h> |
18 | #include <asm/lv1call.h> | 18 | #include <asm/lv1call.h> |
19 | #include <asm/ps3.h> | 19 | #include <asm/ps3.h> |
20 | #include <asm/ps3gpu.h> | ||
20 | 21 | ||
21 | 22 | ||
22 | #define DEVICE_NAME "ps3vram" | 23 | #define DEVICE_NAME "ps3vram" |
@@ -46,8 +47,6 @@ | |||
46 | #define NV_MEMORY_TO_MEMORY_FORMAT_OFFSET_IN 0x0000030c | 47 | #define NV_MEMORY_TO_MEMORY_FORMAT_OFFSET_IN 0x0000030c |
47 | #define NV_MEMORY_TO_MEMORY_FORMAT_NOTIFY 0x00000104 | 48 | #define NV_MEMORY_TO_MEMORY_FORMAT_NOTIFY 0x00000104 |
48 | 49 | ||
49 | #define L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT 0x601 | ||
50 | |||
51 | #define CACHE_PAGE_PRESENT 1 | 50 | #define CACHE_PAGE_PRESENT 1 |
52 | #define CACHE_PAGE_DIRTY 2 | 51 | #define CACHE_PAGE_DIRTY 2 |
53 | 52 | ||
@@ -184,13 +183,10 @@ static void ps3vram_rewind_ring(struct ps3_system_bus_device *dev) | |||
184 | priv->ctrl[CTRL_PUT] = FIFO_BASE + FIFO_OFFSET; | 183 | priv->ctrl[CTRL_PUT] = FIFO_BASE + FIFO_OFFSET; |
185 | 184 | ||
186 | /* asking the HV for a blit will kick the FIFO */ | 185 | /* asking the HV for a blit will kick the FIFO */ |
187 | status = lv1_gpu_context_attribute(priv->context_handle, | 186 | status = lv1_gpu_fb_blit(priv->context_handle, 0, 0, 0, 0); |
188 | L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT, 0, | ||
189 | 0, 0, 0); | ||
190 | if (status) | 187 | if (status) |
191 | dev_err(&dev->core, | 188 | dev_err(&dev->core, "%s: lv1_gpu_fb_blit failed %d\n", |
192 | "%s: lv1_gpu_context_attribute failed %d\n", __func__, | 189 | __func__, status); |
193 | status); | ||
194 | 190 | ||
195 | priv->fifo_ptr = priv->fifo_base; | 191 | priv->fifo_ptr = priv->fifo_base; |
196 | } | 192 | } |
@@ -206,13 +202,10 @@ static void ps3vram_fire_ring(struct ps3_system_bus_device *dev) | |||
206 | (priv->fifo_ptr - priv->fifo_base) * sizeof(u32); | 202 | (priv->fifo_ptr - priv->fifo_base) * sizeof(u32); |
207 | 203 | ||
208 | /* asking the HV for a blit will kick the FIFO */ | 204 | /* asking the HV for a blit will kick the FIFO */ |
209 | status = lv1_gpu_context_attribute(priv->context_handle, | 205 | status = lv1_gpu_fb_blit(priv->context_handle, 0, 0, 0, 0); |
210 | L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT, 0, | ||
211 | 0, 0, 0); | ||
212 | if (status) | 206 | if (status) |
213 | dev_err(&dev->core, | 207 | dev_err(&dev->core, "%s: lv1_gpu_fb_blit failed %d\n", |
214 | "%s: lv1_gpu_context_attribute failed %d\n", __func__, | 208 | __func__, status); |
215 | status); | ||
216 | 209 | ||
217 | if ((priv->fifo_ptr - priv->fifo_base) * sizeof(u32) > | 210 | if ((priv->fifo_ptr - priv->fifo_base) * sizeof(u32) > |
218 | FIFO_SIZE - 1024) { | 211 | FIFO_SIZE - 1024) { |
diff --git a/drivers/ps3/ps3av_cmd.c b/drivers/ps3/ps3av_cmd.c index 716596e8e5b0..f555fedd5073 100644 --- a/drivers/ps3/ps3av_cmd.c +++ b/drivers/ps3/ps3av_cmd.c | |||
@@ -21,9 +21,10 @@ | |||
21 | #include <linux/module.h> | 21 | #include <linux/module.h> |
22 | #include <linux/kernel.h> | 22 | #include <linux/kernel.h> |
23 | #include <linux/delay.h> | 23 | #include <linux/delay.h> |
24 | |||
24 | #include <asm/ps3av.h> | 25 | #include <asm/ps3av.h> |
25 | #include <asm/ps3fb.h> | ||
26 | #include <asm/ps3.h> | 26 | #include <asm/ps3.h> |
27 | #include <asm/ps3gpu.h> | ||
27 | 28 | ||
28 | #include "vuart.h" | 29 | #include "vuart.h" |
29 | 30 | ||
diff --git a/drivers/video/ps3fb.c b/drivers/video/ps3fb.c index a61c1d89bd87..13c876c6e32c 100644 --- a/drivers/video/ps3fb.c +++ b/drivers/video/ps3fb.c | |||
@@ -37,21 +37,11 @@ | |||
37 | #include <asm/ps3av.h> | 37 | #include <asm/ps3av.h> |
38 | #include <asm/ps3fb.h> | 38 | #include <asm/ps3fb.h> |
39 | #include <asm/ps3.h> | 39 | #include <asm/ps3.h> |
40 | #include <asm/ps3gpu.h> | ||
40 | 41 | ||
41 | 42 | ||
42 | #define DEVICE_NAME "ps3fb" | 43 | #define DEVICE_NAME "ps3fb" |
43 | 44 | ||
44 | #define L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_SYNC 0x101 | ||
45 | #define L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_FLIP 0x102 | ||
46 | #define L1GPU_CONTEXT_ATTRIBUTE_FB_SETUP 0x600 | ||
47 | #define L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT 0x601 | ||
48 | #define L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT_SYNC 0x602 | ||
49 | |||
50 | #define L1GPU_FB_BLIT_WAIT_FOR_COMPLETION (1ULL << 32) | ||
51 | |||
52 | #define L1GPU_DISPLAY_SYNC_HSYNC 1 | ||
53 | #define L1GPU_DISPLAY_SYNC_VSYNC 2 | ||
54 | |||
55 | #define GPU_CMD_BUF_SIZE (2 * 1024 * 1024) | 45 | #define GPU_CMD_BUF_SIZE (2 * 1024 * 1024) |
56 | #define GPU_FB_START (64 * 1024) | 46 | #define GPU_FB_START (64 * 1024) |
57 | #define GPU_IOIF (0x0d000000UL) | 47 | #define GPU_IOIF (0x0d000000UL) |
@@ -463,33 +453,27 @@ static void ps3fb_sync_image(struct device *dev, u64 frame_offset, | |||
463 | src_offset += GPU_FB_START; | 453 | src_offset += GPU_FB_START; |
464 | 454 | ||
465 | mutex_lock(&ps3_gpu_mutex); | 455 | mutex_lock(&ps3_gpu_mutex); |
466 | status = lv1_gpu_context_attribute(ps3fb.context_handle, | 456 | status = lv1_gpu_fb_blit(ps3fb.context_handle, dst_offset, |
467 | L1GPU_CONTEXT_ATTRIBUTE_FB_BLIT, | 457 | GPU_IOIF + src_offset, |
468 | dst_offset, GPU_IOIF + src_offset, | 458 | L1GPU_FB_BLIT_WAIT_FOR_COMPLETION | |
469 | L1GPU_FB_BLIT_WAIT_FOR_COMPLETION | | 459 | (width << 16) | height, |
470 | (width << 16) | height, | 460 | line_length); |
471 | line_length); | ||
472 | mutex_unlock(&ps3_gpu_mutex); | 461 | mutex_unlock(&ps3_gpu_mutex); |
473 | 462 | ||
474 | if (status) | 463 | if (status) |
475 | dev_err(dev, | 464 | dev_err(dev, "%s: lv1_gpu_fb_blit failed: %d\n", __func__, |
476 | "%s: lv1_gpu_context_attribute FB_BLIT failed: %d\n", | 465 | status); |
477 | __func__, status); | ||
478 | #ifdef HEAD_A | 466 | #ifdef HEAD_A |
479 | status = lv1_gpu_context_attribute(ps3fb.context_handle, | 467 | status = lv1_gpu_display_flip(ps3fb.context_handle, 0, frame_offset); |
480 | L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_FLIP, | ||
481 | 0, frame_offset, 0, 0); | ||
482 | if (status) | 468 | if (status) |
483 | dev_err(dev, "%s: lv1_gpu_context_attribute FLIP failed: %d\n", | 469 | dev_err(dev, "%s: lv1_gpu_display_flip failed: %d\n", __func__, |
484 | __func__, status); | 470 | status); |
485 | #endif | 471 | #endif |
486 | #ifdef HEAD_B | 472 | #ifdef HEAD_B |
487 | status = lv1_gpu_context_attribute(ps3fb.context_handle, | 473 | status = lv1_gpu_display_flip(ps3fb.context_handle, 1, frame_offset); |
488 | L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_FLIP, | ||
489 | 1, frame_offset, 0, 0); | ||
490 | if (status) | 474 | if (status) |
491 | dev_err(dev, "%s: lv1_gpu_context_attribute FLIP failed: %d\n", | 475 | dev_err(dev, "%s: lv1_gpu_display_flip failed: %d\n", __func__, |
492 | __func__, status); | 476 | status); |
493 | #endif | 477 | #endif |
494 | } | 478 | } |
495 | 479 | ||
@@ -1020,27 +1004,18 @@ static int __devinit ps3fb_probe(struct ps3_system_bus_device *dev) | |||
1020 | init_waitqueue_head(&ps3fb.wait_vsync); | 1004 | init_waitqueue_head(&ps3fb.wait_vsync); |
1021 | 1005 | ||
1022 | #ifdef HEAD_A | 1006 | #ifdef HEAD_A |
1023 | status = lv1_gpu_context_attribute(0x0, | 1007 | status = lv1_gpu_display_sync(0x0, 0, L1GPU_DISPLAY_SYNC_VSYNC); |
1024 | L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_SYNC, | ||
1025 | 0, L1GPU_DISPLAY_SYNC_VSYNC, 0, 0); | ||
1026 | if (status) { | 1008 | if (status) { |
1027 | dev_err(&dev->core, | 1009 | dev_err(&dev->core, "%s: lv1_gpu_display_sync failed: %d\n", |
1028 | "%s: lv1_gpu_context_attribute DISPLAY_SYNC failed: " | ||
1029 | "%d\n", | ||
1030 | __func__, status); | 1010 | __func__, status); |
1031 | retval = -ENODEV; | 1011 | retval = -ENODEV; |
1032 | goto err_close_device; | 1012 | goto err_close_device; |
1033 | } | 1013 | } |
1034 | #endif | 1014 | #endif |
1035 | #ifdef HEAD_B | 1015 | #ifdef HEAD_B |
1036 | status = lv1_gpu_context_attribute(0x0, | 1016 | status = lv1_gpu_display_sync(0x0, 1, L1GPU_DISPLAY_SYNC_VSYNC); |
1037 | L1GPU_CONTEXT_ATTRIBUTE_DISPLAY_SYNC, | ||
1038 | 1, L1GPU_DISPLAY_SYNC_VSYNC, 0, 0); | ||
1039 | |||
1040 | if (status) { | 1017 | if (status) { |
1041 | dev_err(&dev->core, | 1018 | dev_err(&dev->core, "%s: lv1_gpu_display_sync failed: %d\n", |
1042 | "%s: lv1_gpu_context_attribute DISPLAY_SYNC failed: " | ||
1043 | "%d\n", | ||
1044 | __func__, status); | 1019 | __func__, status); |
1045 | retval = -ENODEV; | 1020 | retval = -ENODEV; |
1046 | goto err_close_device; | 1021 | goto err_close_device; |
@@ -1070,7 +1045,7 @@ static int __devinit ps3fb_probe(struct ps3_system_bus_device *dev) | |||
1070 | &lpar_reports, &lpar_reports_size); | 1045 | &lpar_reports, &lpar_reports_size); |
1071 | if (status) { | 1046 | if (status) { |
1072 | dev_err(&dev->core, | 1047 | dev_err(&dev->core, |
1073 | "%s: lv1_gpu_context_attribute failed: %d\n", __func__, | 1048 | "%s: lv1_gpu_context_allocate failed: %d\n", __func__, |
1074 | status); | 1049 | status); |
1075 | goto err_gpu_memory_free; | 1050 | goto err_gpu_memory_free; |
1076 | } | 1051 | } |
@@ -1137,13 +1112,10 @@ static int __devinit ps3fb_probe(struct ps3_system_bus_device *dev) | |||
1137 | ps3fb_videomemory.address, GPU_IOIF, xdr_lpar, | 1112 | ps3fb_videomemory.address, GPU_IOIF, xdr_lpar, |
1138 | ps3fb_videomemory.size); | 1113 | ps3fb_videomemory.size); |
1139 | 1114 | ||
1140 | status = lv1_gpu_context_attribute(ps3fb.context_handle, | 1115 | status = lv1_gpu_fb_setup(ps3fb.context_handle, xdr_lpar, |
1141 | L1GPU_CONTEXT_ATTRIBUTE_FB_SETUP, | 1116 | GPU_CMD_BUF_SIZE, GPU_IOIF); |
1142 | xdr_lpar, GPU_CMD_BUF_SIZE, | ||
1143 | GPU_IOIF, 0); | ||
1144 | if (status) { | 1117 | if (status) { |
1145 | dev_err(&dev->core, | 1118 | dev_err(&dev->core, "%s: lv1_gpu_fb_setup failed: %d\n", |
1146 | "%s: lv1_gpu_context_attribute FB_SETUP failed: %d\n", | ||
1147 | __func__, status); | 1119 | __func__, status); |
1148 | retval = -ENXIO; | 1120 | retval = -ENXIO; |
1149 | goto err_context_unmap; | 1121 | goto err_context_unmap; |