annotate TaskManager/Cell/spe/CellDmaManager.cc @ 88:504899860e66

*** empty log message ***
author gongo
date Wed, 27 Feb 2008 17:16:29 +0900
parents 6bc72fde6615
children 5c194c71eca8
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 (buf == NULL || (void*)addr == NULL) return;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
10 if (size == 0) return ;
59
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
11 spu_mfcdma32(buf, addr, ROUND_UP_ALIGN(size, DEFAULT_ALIGNMENT),
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
12 mask, MFC_GET_CMD);
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
13 }
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
14
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
15 void
88
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
16 CellDmaManager::dma_store(void *buf, uint32 addr, uint32 size, uint32 mask)
59
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
17 {
88
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
18 //if (buf == NULL || (void*)addr == NULL) return;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
19 if (size == 0) return ;
59
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
20 spu_mfcdma32(buf, addr, ROUND_UP_ALIGN(size, DEFAULT_ALIGNMENT),
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
21 mask, MFC_PUT_CMD);
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
22 }
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
23
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
24 /**
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
25 * mask で設定した DMA 転送の完了を待つ
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
26 */
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
27 void
88
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
28 CellDmaManager::dma_wait(uint32 mask)
59
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
29 {
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
30 spu_writech(MFC_WrTagMask, 1 << mask);
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
31 spu_mfcstat(MFC_TAG_UPDATE_ALL);
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
32 }
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
33
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
34 void
88
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
35 CellDmaManager::mail_write(uint32 data)
59
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
36 {
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
37 spu_writech(SPU_WrOutMbox, data);
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
38 }
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
39
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
40 unsigned int
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
41 CellDmaManager::mail_read(void)
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
42 {
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
43 return spu_readch(SPU_RdInMbox);
16f9f6251f49 *** empty log message ***
gongo
parents:
diff changeset
44 }
88
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
45
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
46 void
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
47 CellDmaManager::dmaList_set(uint32 _address, uint32 _size)
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
48 {
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
49 int *index = &buff_index[buff_flag];
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
50 DmaListPtr queue = &dmaQueue[buff_flag][(*index)++];
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
51
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
52 queue->addr = _address;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
53 queue->size = ROUND_UP_ALIGN(_size, DEFAULT_ALIGNMENT);
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
54 }
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
55
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
56 void**
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
57 CellDmaManager::dmaList_load(uint32 mask)
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
58 {
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
59 int index = buff_index[buff_flag];
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
60 DmaListPtr queue = dmaQueue[buff_flag];
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
61 mfc_list_element_t *mfc_list = mfcList[buff_flag];
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
62
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
63 void **buffList;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
64 void *buff;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
65 int bound;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
66 int total_size = 0;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
67
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
68 mfc_list = (mfc_list_element_t *)malloc(sizeof(mfc_list_element_t)*index);
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
69
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
70 for (int i = 0; i < index; i++) {
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
71 mfc_list[i].notify = 0;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
72 mfc_list[i].reserved = 0;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
73 mfc_list[i].size = queue[i].size;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
74 mfc_list[i].eal = queue[i].addr;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
75 total_size += queue[i].size;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
76 }
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
77
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
78 //----------------------------------------------------------------
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
79 // list element が n 個ある場合の buff, buffList の構造
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
80 //
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
81 // +---------------+---------------+--------+-----------------+
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
82 // buff | queue[0].size | queue[1].size | ...... | queue[n-1].size |
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
83 // +---------------+---------------+--------+-----------------+
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
84 // ^ ^ ^ ^
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
85 // | | | |
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
86 // buffList[0] buffList[1] buffList[2] buffList[n-1]
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
87 //----------------------------------------------------------------
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
88
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
89 buff = memalign(DEFAULT_ALIGNMENT, total_size);
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
90 buffList = (void**)malloc(index);
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
91
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
92 bound = (int)buff;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
93 buffList[0] = (void*)bound;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
94 for (int i = 1; i < index; i++) {
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
95 bound += queue[i-1].size;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
96 buffList[i] = (void*)bound;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
97 }
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
98
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
99 mfc_getl(buff, 0, mfc_list, sizeof(mfc_list_element_t), mask, 0, 0);
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
100 dma_wait(mask);
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
101
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
102 _buffList[buff_flag] = buffList;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
103 _buff[buff_flag] = buff;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
104
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
105 return buffList;
504899860e66 *** empty log message ***
gongo
parents: 61
diff changeset
106 }