annotate TaskManager/Cell/spe/CellDmaManager.cc @ 109:5c194c71eca8

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