annotate liboffloadmic/runtime/dv_util.cpp @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /*
kono
parents:
diff changeset
2 Copyright (c) 2014-2016 Intel Corporation. All Rights Reserved.
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 Redistribution and use in source and binary forms, with or without
kono
parents:
diff changeset
5 modification, are permitted provided that the following conditions
kono
parents:
diff changeset
6 are met:
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 * Redistributions of source code must retain the above copyright
kono
parents:
diff changeset
9 notice, this list of conditions and the following disclaimer.
kono
parents:
diff changeset
10 * Redistributions in binary form must reproduce the above copyright
kono
parents:
diff changeset
11 notice, this list of conditions and the following disclaimer in the
kono
parents:
diff changeset
12 documentation and/or other materials provided with the distribution.
kono
parents:
diff changeset
13 * Neither the name of Intel Corporation nor the names of its
kono
parents:
diff changeset
14 contributors may be used to endorse or promote products derived
kono
parents:
diff changeset
15 from this software without specific prior written permission.
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
kono
parents:
diff changeset
18 "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
kono
parents:
diff changeset
19 LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
kono
parents:
diff changeset
20 A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
kono
parents:
diff changeset
21 HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
kono
parents:
diff changeset
22 SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
kono
parents:
diff changeset
23 LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
kono
parents:
diff changeset
24 DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
kono
parents:
diff changeset
25 THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
kono
parents:
diff changeset
26 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
kono
parents:
diff changeset
27 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
kono
parents:
diff changeset
28 */
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 #include "offload_common.h"
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 bool __dv_is_contiguous(const ArrDesc *dvp)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 if (dvp->Flags & ArrDescFlagsContiguous) {
kono
parents:
diff changeset
36 return true;
kono
parents:
diff changeset
37 }
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 if (dvp->Rank != 0) {
kono
parents:
diff changeset
40 if (dvp->Dim[0].Mult != dvp->Len) {
kono
parents:
diff changeset
41 return false;
kono
parents:
diff changeset
42 }
kono
parents:
diff changeset
43 for (int i = 1; i < dvp->Rank; i++) {
kono
parents:
diff changeset
44 if (dvp->Dim[i].Mult !=
kono
parents:
diff changeset
45 dvp->Dim[i-1].Extent * dvp->Dim[i-1].Mult) {
kono
parents:
diff changeset
46 return false;
kono
parents:
diff changeset
47 }
kono
parents:
diff changeset
48 }
kono
parents:
diff changeset
49 }
kono
parents:
diff changeset
50 return true;
kono
parents:
diff changeset
51 }
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 bool __dv_is_allocated(const ArrDesc *dvp)
kono
parents:
diff changeset
54 {
kono
parents:
diff changeset
55 return (dvp->Flags & ArrDescFlagsDefined);
kono
parents:
diff changeset
56 }
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 uint64_t __dv_data_length(const ArrDesc *dvp)
kono
parents:
diff changeset
59 {
kono
parents:
diff changeset
60 uint64_t size;
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 if (dvp->Rank == 0) {
kono
parents:
diff changeset
63 size = dvp->Len;
kono
parents:
diff changeset
64 return size;
kono
parents:
diff changeset
65 }
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 size = dvp->Len;
kono
parents:
diff changeset
68 for (int i = 0; i < dvp->Rank; ++i) {
kono
parents:
diff changeset
69 size += (dvp->Dim[i].Extent-1) * dvp->Dim[i].Mult;
kono
parents:
diff changeset
70 }
kono
parents:
diff changeset
71 return size;
kono
parents:
diff changeset
72 }
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 uint64_t __dv_data_length(const ArrDesc *dvp, int64_t count)
kono
parents:
diff changeset
75 {
kono
parents:
diff changeset
76 if (dvp->Rank == 0) {
kono
parents:
diff changeset
77 return count;
kono
parents:
diff changeset
78 }
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 return count * dvp->Dim[0].Mult;
kono
parents:
diff changeset
81 }
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 // Create CeanReadRanges data for reading contiguous ranges of
kono
parents:
diff changeset
84 // noncontiguous array defined by the argument
kono
parents:
diff changeset
85 CeanReadRanges * init_read_ranges_dv(const ArrDesc *dvp)
kono
parents:
diff changeset
86 {
kono
parents:
diff changeset
87 int64_t len;
kono
parents:
diff changeset
88 int count;
kono
parents:
diff changeset
89 int rank = dvp->Rank;
kono
parents:
diff changeset
90 CeanReadRanges *res = NULL;
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 if (rank != 0) {
kono
parents:
diff changeset
93 int i = 0;
kono
parents:
diff changeset
94 len = dvp->Len;
kono
parents:
diff changeset
95 if (dvp->Dim[0].Mult == len) {
kono
parents:
diff changeset
96 for (i = 1; i < rank; i++) {
kono
parents:
diff changeset
97 len *= dvp->Dim[i-1].Extent;
kono
parents:
diff changeset
98 if (dvp->Dim[i].Mult != len) {
kono
parents:
diff changeset
99 break;
kono
parents:
diff changeset
100 }
kono
parents:
diff changeset
101 }
kono
parents:
diff changeset
102 }
kono
parents:
diff changeset
103 res = (CeanReadRanges *)malloc(
kono
parents:
diff changeset
104 sizeof(CeanReadRanges) + (rank - i) * sizeof(CeanReadDim));
kono
parents:
diff changeset
105 if (res == NULL)
kono
parents:
diff changeset
106 LIBOFFLOAD_ERROR(c_malloc);
kono
parents:
diff changeset
107 res -> last_noncont_ind = rank - i - 1;
kono
parents:
diff changeset
108 count = 1;
kono
parents:
diff changeset
109 for (; i < rank; i++) {
kono
parents:
diff changeset
110 res->Dim[rank - i - 1].count = count;
kono
parents:
diff changeset
111 res->Dim[rank - i - 1].size = dvp->Dim[i].Mult;
kono
parents:
diff changeset
112 count *= dvp->Dim[i].Extent;
kono
parents:
diff changeset
113 }
kono
parents:
diff changeset
114 res -> range_max_number = count;
kono
parents:
diff changeset
115 res -> range_size = len;
kono
parents:
diff changeset
116 res -> ptr = (void*)dvp->Base;
kono
parents:
diff changeset
117 res -> current_number = 0;
kono
parents:
diff changeset
118 res -> init_offset = 0;
kono
parents:
diff changeset
119 }
kono
parents:
diff changeset
120 return res;
kono
parents:
diff changeset
121 }
kono
parents:
diff changeset
122
kono
parents:
diff changeset
123 #if OFFLOAD_DEBUG > 0
kono
parents:
diff changeset
124 void __dv_desc_dump(const char *name, const ArrDesc *dvp)
kono
parents:
diff changeset
125 {
kono
parents:
diff changeset
126 OFFLOAD_TRACE(3, "%s DV %p\n", name, dvp);
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 if (dvp != 0) {
kono
parents:
diff changeset
129 OFFLOAD_TRACE(3,
kono
parents:
diff changeset
130 " dv->Base = 0x%lx\n"
kono
parents:
diff changeset
131 " dv->Len = 0x%lx\n"
kono
parents:
diff changeset
132 " dv->Offset = 0x%lx\n"
kono
parents:
diff changeset
133 " dv->Flags = 0x%lx\n"
kono
parents:
diff changeset
134 " dv->Rank = 0x%lx\n"
kono
parents:
diff changeset
135 " dv->Resrvd = 0x%lx\n",
kono
parents:
diff changeset
136 dvp->Base,
kono
parents:
diff changeset
137 dvp->Len,
kono
parents:
diff changeset
138 dvp->Offset,
kono
parents:
diff changeset
139 dvp->Flags,
kono
parents:
diff changeset
140 dvp->Rank,
kono
parents:
diff changeset
141 dvp->Reserved);
kono
parents:
diff changeset
142
kono
parents:
diff changeset
143 for (int i = 0 ; i < dvp->Rank; i++) {
kono
parents:
diff changeset
144 OFFLOAD_TRACE(3,
kono
parents:
diff changeset
145 " (%d) Extent=%ld, Multiplier=%ld, LowerBound=%ld\n",
kono
parents:
diff changeset
146 i,
kono
parents:
diff changeset
147 dvp->Dim[i].Extent,
kono
parents:
diff changeset
148 dvp->Dim[i].Mult,
kono
parents:
diff changeset
149 dvp->Dim[i].LowerBound);
kono
parents:
diff changeset
150 }
kono
parents:
diff changeset
151 }
kono
parents:
diff changeset
152 }
kono
parents:
diff changeset
153 #endif // OFFLOAD_DEBUG > 0