61
|
1 #include <stdio.h>
|
88
|
2 #include <stdlib.h>
|
|
3 #include <malloc.h>
|
59
|
4 #include "CellDmaManager.h"
|
|
5
|
|
6 void
|
88
|
7 CellDmaManager::dma_load(void *buf, uint32 addr, uint32 size, uint32 mask)
|
59
|
8 {
|
88
|
9 if (size == 0) return ;
|
109
|
10 spu_mfcdma32(buf, addr, size, mask, MFC_GET_CMD);
|
59
|
11 }
|
|
12
|
|
13 void
|
88
|
14 CellDmaManager::dma_store(void *buf, uint32 addr, uint32 size, uint32 mask)
|
59
|
15 {
|
88
|
16 if (size == 0) return ;
|
109
|
17 spu_mfcdma32(buf, addr, size, mask, MFC_PUT_CMD);
|
|
18
|
|
19 //spu_mfcdma32(buf, addr, ROUND_UP_ALIGN(size, DEFAULT_ALIGNMENT),
|
59
|
20 }
|
|
21
|
|
22 /**
|
|
23 * mask で設定した DMA 転送の完了を待つ
|
|
24 */
|
|
25 void
|
88
|
26 CellDmaManager::dma_wait(uint32 mask)
|
59
|
27 {
|
|
28 spu_writech(MFC_WrTagMask, 1 << mask);
|
|
29 spu_mfcstat(MFC_TAG_UPDATE_ALL);
|
|
30 }
|
|
31
|
|
32 void
|
88
|
33 CellDmaManager::mail_write(uint32 data)
|
59
|
34 {
|
|
35 spu_writech(SPU_WrOutMbox, data);
|
|
36 }
|
|
37
|
|
38 unsigned int
|
|
39 CellDmaManager::mail_read(void)
|
|
40 {
|
109
|
41 unsigned int mail = spu_readch(SPU_RdInMbox);
|
|
42 return mail;
|
|
43 }
|
|
44
|
|
45 void
|
|
46 CellDmaManager::dma_loadList(ListDataPtr list, void *buff, uint32 mask)
|
|
47 {
|
|
48 mfc_getl(buff, 0, list->element, sizeof(mfc_list_element_t)*list->length,
|
|
49 mask, 0, 0);
|
59
|
50 }
|
88
|
51
|
|
52 void
|
109
|
53 CellDmaManager::dma_storeList(ListDataPtr list, void *buff, uint32 mask)
|
88
|
54 {
|
109
|
55 mfc_putl(buff, 0, list->element, sizeof(mfc_list_element_t)*list->length,
|
|
56 mask, 0, 0);
|
|
57 }
|
|
58
|
88
|
59
|
109
|
60 #if 0
|
|
61 /**
|
|
62 * dma_loadList の前ばーじょn
|
|
63 */
|
88
|
64
|
|
65 void**
|
|
66 CellDmaManager::dmaList_load(uint32 mask)
|
|
67 {
|
|
68 int index = buff_index[buff_flag];
|
|
69 DmaListPtr queue = dmaQueue[buff_flag];
|
|
70 mfc_list_element_t *mfc_list = mfcList[buff_flag];
|
|
71
|
|
72 void **buffList;
|
|
73 void *buff;
|
|
74 int bound;
|
|
75 int total_size = 0;
|
|
76
|
|
77 mfc_list = (mfc_list_element_t *)malloc(sizeof(mfc_list_element_t)*index);
|
|
78
|
|
79 for (int i = 0; i < index; i++) {
|
|
80 mfc_list[i].notify = 0;
|
|
81 mfc_list[i].reserved = 0;
|
|
82 mfc_list[i].size = queue[i].size;
|
|
83 mfc_list[i].eal = queue[i].addr;
|
|
84 total_size += queue[i].size;
|
|
85 }
|
|
86
|
|
87 //----------------------------------------------------------------
|
|
88 // list element が n 個ある場合の buff, buffList の構造
|
|
89 //
|
|
90 // +---------------+---------------+--------+-----------------+
|
|
91 // buff | queue[0].size | queue[1].size | ...... | queue[n-1].size |
|
|
92 // +---------------+---------------+--------+-----------------+
|
|
93 // ^ ^ ^ ^
|
|
94 // | | | |
|
|
95 // buffList[0] buffList[1] buffList[2] buffList[n-1]
|
|
96 //----------------------------------------------------------------
|
|
97
|
|
98 buff = memalign(DEFAULT_ALIGNMENT, total_size);
|
|
99 buffList = (void**)malloc(index);
|
|
100
|
|
101 bound = (int)buff;
|
|
102 buffList[0] = (void*)bound;
|
|
103 for (int i = 1; i < index; i++) {
|
|
104 bound += queue[i-1].size;
|
|
105 buffList[i] = (void*)bound;
|
|
106 }
|
|
107
|
|
108 mfc_getl(buff, 0, mfc_list, sizeof(mfc_list_element_t), mask, 0, 0);
|
|
109 dma_wait(mask);
|
|
110
|
|
111 _buffList[buff_flag] = buffList;
|
|
112 _buff[buff_flag] = buff;
|
|
113
|
|
114 return buffList;
|
|
115 }
|
109
|
116 #endif
|