author | Jan Vrany <jan.vrany@fit.cvut.cz> |
Wed, 12 Jun 2019 15:02:01 +0100 | |
branch | jv |
changeset 24334 | e82c3f5bc1f1 |
parent 23107 | 40173e082cbc |
child 25391 | cad52f81f60c |
permissions | -rw-r--r-- |
6459 | 1 |
" |
2 |
COPYRIGHT (c) 1993 by Claus Gittinger |
|
23107 | 3 |
COPYRIGHT (c) 2018 Jan Vrany |
6459 | 4 |
All Rights Reserved |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
5 |
|
6459 | 6 |
This software is furnished under a license and may be used |
7 |
only in accordance with the terms of that license and with the |
|
8 |
inclusion of the above copyright notice. This software may not |
|
9 |
be provided or otherwise made available to, or used by, any |
|
10 |
other person. No title to or ownership of the software is |
|
11 |
hereby transferred. |
|
12 |
" |
|
5378 | 13 |
"{ Package: 'stx:libbasic' }" |
14 |
||
17627 | 15 |
"{ NameSpace: Smalltalk }" |
16 |
||
3208
2d71538b9fd5
now subclass of UIBytes - which contains common protocol
Claus Gittinger <cg@exept.de>
parents:
3206
diff
changeset
|
17 |
UninterpretedBytes subclass:#ExternalBytes |
3211
ef7a5411afa1
remove methods which are provided by my (new) superClass
Claus Gittinger <cg@exept.de>
parents:
3208
diff
changeset
|
18 |
instanceVariableNames:'address* size' |
10137
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
19 |
classVariableNames:'AllocatedInstances Lobby DebugMalloc TraceMalloc' |
3211
ef7a5411afa1
remove methods which are provided by my (new) superClass
Claus Gittinger <cg@exept.de>
parents:
3208
diff
changeset
|
20 |
poolDictionaries:'' |
ef7a5411afa1
remove methods which are provided by my (new) superClass
Claus Gittinger <cg@exept.de>
parents:
3208
diff
changeset
|
21 |
category:'System-Support' |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
22 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
23 |
|
14749 | 24 |
!ExternalBytes primitiveDefinitions! |
25 |
%{ |
|
19376 | 26 |
#include <stdlib.h> |
27 |
#include <stdio.h> |
|
19392 | 28 |
// cg: not needed |
29 |
#if 0 |
|
30 |
# ifdef __osx__ |
|
31 |
# include <sys/malloc.h> |
|
32 |
# else |
|
33 |
# include <malloc.h> |
|
34 |
# endif |
|
35 |
#endif |
|
19376 | 36 |
|
37 |
extern char *__stx_malloc(size_t); |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
38 |
extern char *__stx_calloc(size_t, size_t); |
19376 | 39 |
extern char *__stx_realloc(char *, size_t); |
40 |
extern void __stx_free(char *); |
|
41 |
extern void __stx_mallocStatistics(void); |
|
14749 | 42 |
%} |
43 |
! ! |
|
44 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
45 |
!ExternalBytes primitiveFunctions! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
46 |
%{ |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
47 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
48 |
struct mallocList { |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
49 |
char *chunk; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
50 |
size_t size; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
51 |
struct mallocList *next; |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
52 |
}; |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
53 |
static struct mallocList *mallocList = (struct mallocList *)0; |
8913 | 54 |
static INT mallocCount = 0; |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
55 |
|
6242 | 56 |
static void |
19376 | 57 |
removeFromMallocList(char *ptr) |
6242 | 58 |
{ |
59 |
struct mallocList *this, *prev, *next; |
|
60 |
int found = 0; |
|
61 |
||
62 |
if (@global(DebugMalloc) != true) return; |
|
63 |
||
64 |
if (ptr) { |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
65 |
found = 0; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
66 |
for (this=mallocList, prev=0; this; this=next) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
67 |
next = this->next; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
68 |
if (this->chunk == ptr) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
69 |
if (prev) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
70 |
prev->next = next; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
71 |
} else { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
72 |
mallocList = next; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
73 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
74 |
free(this); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
75 |
found++; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
76 |
mallocCount--; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
77 |
} else { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
78 |
prev = this; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
79 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
80 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
81 |
if (! found) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
82 |
console_printf("ExternalBytes [warning]: **** free: alien %"_lx_" (allocated somewhere else ?))\n", (INT)ptr); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
83 |
} |
6242 | 84 |
} |
85 |
} |
|
86 |
||
87 |
static void |
|
19376 | 88 |
addToMallocList(char *ptr, size_t nBytes) |
6242 | 89 |
{ |
90 |
struct mallocList *e, *this; |
|
9895 | 91 |
void *malloc(); |
6242 | 92 |
int found; |
93 |
||
94 |
if (@global(DebugMalloc) != true) return; |
|
95 |
||
96 |
if (ptr) { |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
97 |
found = 0; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
98 |
for (this=mallocList; this; this=this->next) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
99 |
if (this->chunk == ptr) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
100 |
console_printf("ExternalBytes [warning]: **** %016"_lx_" already allocated (freed somewhere else ?)\n", (INT)ptr); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
101 |
found++; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
102 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
103 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
104 |
if (! found) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
105 |
e = (struct mallocList *) malloc(sizeof(struct mallocList)); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
106 |
e->next = mallocList; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
107 |
e->chunk = ptr; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
108 |
e->size = nBytes; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
109 |
mallocList = e; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
110 |
mallocCount++; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
111 |
} |
6242 | 112 |
} |
113 |
} |
|
114 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
115 |
char * |
19376 | 116 |
__stx_malloc(size_t nBytes) { |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
117 |
char *ptr = malloc(nBytes); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
118 |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
119 |
if (@global(TraceMalloc) == true) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
120 |
console_printf("ExternalBytes [info]: allocated %d bytes at: %016"_lx_"\n", nBytes, (INT)ptr); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
121 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
122 |
addToMallocList(ptr, nBytes); |
6242 | 123 |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
124 |
return ptr; |
19376 | 125 |
} |
6242 | 126 |
|
19376 | 127 |
char * |
128 |
__stx_calloc(size_t n, size_t size) { |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
129 |
char *ptr = __stx_malloc(n * size); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
130 |
if (ptr != 0) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
131 |
bzero(ptr, (n * size)); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
132 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
133 |
return ptr; |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
134 |
} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
135 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
136 |
char * |
19376 | 137 |
__stx_realloc(char *ptr, size_t nBytes) |
138 |
{ |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
139 |
char *newPtr; |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
140 |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
141 |
removeFromMallocList(ptr); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
142 |
newPtr = realloc(ptr, nBytes); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
143 |
addToMallocList(newPtr, nBytes); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
144 |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
145 |
if (@global(TraceMalloc) == true) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
146 |
console_printf("ExternalBytes [info]: realloc %d bytes for %"_lx_" at: %"_lx_"\n", nBytes, (INT)ptr, (INT)newPtr); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
147 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
148 |
return newPtr; |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
149 |
} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
150 |
|
18653 | 151 |
void |
19376 | 152 |
__stx_free(char *ptr) |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
153 |
{ |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
154 |
if (@global(TraceMalloc) == true) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
155 |
console_printf("ExternalBytes: free bytes at: %"_lx_"\n", (INT)ptr); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
156 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
157 |
removeFromMallocList(ptr); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
158 |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
159 |
free(ptr); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
160 |
} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
161 |
|
18653 | 162 |
void |
3320 | 163 |
__stx_mallocStatistics() { |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
164 |
struct mallocList *this; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
165 |
int amount = 0; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
166 |
int n = 0; |
3320 | 167 |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
168 |
for (this=mallocList; this; this=this->next) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
169 |
n++; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
170 |
amount += this->size; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
171 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
172 |
console_printf("ExternalBytes [info]: allocated %d blocks with %d bytes overall\n", n, amount); |
3320 | 173 |
} |
174 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
175 |
%} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
176 |
! ! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
177 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
178 |
!ExternalBytes class methodsFor:'documentation'! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
179 |
|
6459 | 180 |
copyright |
181 |
" |
|
182 |
COPYRIGHT (c) 1993 by Claus Gittinger |
|
23107 | 183 |
COPYRIGHT (c) 2018 Jan Vrany |
6459 | 184 |
All Rights Reserved |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
185 |
|
6459 | 186 |
This software is furnished under a license and may be used |
187 |
only in accordance with the terms of that license and with the |
|
188 |
inclusion of the above copyright notice. This software may not |
|
189 |
be provided or otherwise made available to, or used by, any |
|
190 |
other person. No title to or ownership of the software is |
|
191 |
hereby transferred. |
|
192 |
" |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
193 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
194 |
|
6459 | 195 |
documentation |
196 |
" |
|
197 |
This class provides access to any memory in the system. Its main purpose |
|
8908 | 198 |
is to provide a baseclass for objects referencing structured external data. |
6459 | 199 |
Normally, instances are created by primitive code which wants to pass C-data |
200 |
to Smalltalk AND grants smalltalk access to individual bytes afterwards. |
|
201 |
Primitives which do not want to grant this access should return instances of |
|
202 |
ExternalAddress. See more info there. Also, have a look at ExternalFunction |
|
203 |
which is another similar class, but specialized to represent callable C-functions. |
|
8908 | 204 |
|
6459 | 205 |
Since the memory address of an instance stays fixed (once allocated), |
8908 | 206 |
it can also be used to share data with external C-parts |
6459 | 207 |
(which are not prepared for objects to change their address). |
208 |
||
8908 | 209 |
Use with great care - access is not always checked for out-of-bounds |
6459 | 210 |
or valid addresses. |
211 |
||
212 |
Since the data is allocated outside the garbage collected smalltalk space, |
|
213 |
its address stays fix. Thus, it can be passed to external C-functions without |
|
214 |
any danger. However, you have to take care for freeing the memory yourself. |
|
215 |
||
8908 | 216 |
To help in avoiding memory bugs, instances created with #new: are |
6459 | 217 |
registered in a local classvar and deregistered when the underlying memory |
218 |
is explicitely freed. Since a life reference (from that classvar) exists, |
|
219 |
the garbage collector will never find these to be reclaimable, and the |
|
220 |
underlying memory stays allocated (at a fix address) forever. |
|
221 |
To release the memory, either #free it or #unprotect it. |
|
222 |
The first will immediately release the memory, while the second will delay |
|
223 |
freeing until the next garbage collect occurs. |
|
224 |
||
225 |
If you need memory which is automatically freed, create |
|
226 |
the instance via #unprotectedNew: right away; the underlying malloced-memory |
|
227 |
will be released as soon as no smalltalk reference to the ExtBytes object |
|
228 |
exists any more (however, you have to know for sure, that no C-references |
|
229 |
exist to this memory). |
|
230 |
||
8908 | 231 |
To release all memory call #releaseAllMemory which simply sets the |
6459 | 232 |
AllocatedInstances class variable to nil (thus releasing those refs). |
233 |
||
234 |
Example (automatic freeing as soon as ref to buffer is gone): |
|
235 |
|buffer| |
|
236 |
||
237 |
buffer := ExternalBytes unprotectedNew:100. |
|
238 |
... |
|
239 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
240 |
|
6459 | 241 |
Example (manual freeing - never freed, if ref to buffer is gone): |
242 |
|buffer| |
|
243 |
||
244 |
buffer := ExternalBytes new:100. |
|
245 |
... |
|
246 |
buffer free |
|
247 |
||
248 |
||
249 |
Example (delayed automatic freeing as soon as ref to buffer is gone): |
|
250 |
|buffer| |
|
251 |
||
252 |
buffer := ExternalBytes new:100. |
|
253 |
... |
|
254 |
buffer unregister |
|
255 |
||
8908 | 256 |
This class only supports unstructured external data |
6459 | 257 |
- see the companion class ExternalStructure for more. |
258 |
||
259 |
Notice: support for external data is still being developed - |
|
260 |
a parser for C structure syntax and typedefs is on the way, |
|
261 |
making shared data with C programs much easier in the future. |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
262 |
|
6459 | 263 |
Also notice, that this class may not be available or behave different |
264 |
in other smalltalk systems, making code using it very unportable. |
|
265 |
It is provided for C interfacing only. |
|
266 |
||
267 |
Finally note, that ST/X's memory system is much faster than malloc/free |
|
268 |
in the normal case - especially for short term temporary objects, |
|
269 |
automatically reclaimed object memory is about 5-10 times faster than |
|
270 |
malloc/free. |
|
271 |
Things may be different for huge byte-valued objects, which are to be |
|
8908 | 272 |
reclaimed by the oldspace colletor. |
273 |
Anyway, for portability, we strongly warn from using this as a substitute |
|
6459 | 274 |
for byteArrays; it is meant for shared data with external C-functions ONLY. |
275 |
||
8908 | 276 |
Debugging: |
6459 | 277 |
since all manual memory systems are subject of obscure errors, |
278 |
you may want to turn malloc-tracing on; this traces all allocations/frees |
|
279 |
done here. To do this, evaluate: 'ExternalBytes mallocTrace:true'. |
|
280 |
||
281 |
In addition, you may turn on full debugging (with 'ExternalBytes mallocDebug:true'); |
|
282 |
if turned on, all malloc/realloc requests are remembered and later free / realloc |
|
283 |
requests validated against this list (i.e. to detect freeing unallocated chunks). |
|
284 |
||
285 |
To benefit from this in C-code, we recommend you use __stx_malloc() / __stx_free() |
|
286 |
instead of malloc() / free(). To do so, redefine them in a header file (or cc comand line) |
|
6242 | 287 |
and recompile your external c-libraries with this. |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
288 |
|
6242 | 289 |
I used this here to find memory leaks in the Xt libraries (there are still some in |
290 |
the HTML widget ...). If mallocDebug is on, #dumpMallocChunks will print out what is |
|
291 |
leftOver. This may help to find trouble spots in your C-code. |
|
1286 | 292 |
|
293 |
[author:] |
|
6242 | 294 |
Claus Gittinger |
1317 | 295 |
|
296 |
[see also:] |
|
6242 | 297 |
ExternalAddress ExternalFunction |
298 |
ByteArray |
|
299 |
( how to write primitive code :html: programming/primitive.html ) |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
300 |
" |
6459 | 301 |
! |
302 |
||
8908 | 303 |
examples |
6459 | 304 |
" |
305 |
These examples below are not directly executable; |
|
7191
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
306 |
some require primitive code to be compiled, or are simply given as sceletton. |
6459 | 307 |
Notice, that in C, indexing is 0-based, while in Smalltalk, indices start |
308 |
at 1. |
|
309 |
||
310 |
allocating memory in ST, passing it to C: |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
311 |
|
6459 | 312 |
in smalltalk: |
8908 | 313 |
... |
314 |
bytes := ExternalBytes new:100. |
|
315 |
... |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
316 |
|
6459 | 317 |
in C (assuming that the bytes-object has been passed): |
318 |
||
8908 | 319 |
... |
320 |
char *bytePtr; |
|
6459 | 321 |
|
8908 | 322 |
bytePtr = (char *)(__externalBytesAddress(bytes)); |
323 |
if (bytePtr) { |
|
324 |
... do something with bytes at bytePtr ... |
|
325 |
} |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
326 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
327 |
freeing (in ST): |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
328 |
|
8908 | 329 |
... |
330 |
bytes free. |
|
331 |
... |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
332 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
333 |
allocating memory in C, passing it to ST: |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
334 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
335 |
in C: |
8908 | 336 |
... |
337 |
char *bytePtr; |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
338 |
|
8908 | 339 |
bytePtr = (char *)(malloc(100)); |
340 |
... |
|
341 |
RETURN (__MKEXTERNALBYTES(bytePtr)); |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
342 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
343 |
in Smalltalk (extracting bytes, integers or strings): |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
344 |
|
8908 | 345 |
byteVal := bytes byteAt:1. |
346 |
... |
|
347 |
intVal := bytes doubleWordAt:1 MSB:true. |
|
348 |
... |
|
349 |
string := bytes stringAt:20. |
|
350 |
... |
|
7191
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
351 |
|
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
352 |
|
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
353 |
|data bytes2| |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
354 |
|
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
355 |
data := #[0 1 2 3 4 5 6 7 8 9 9 8 7 6 5 4 3 2 1 0] copy. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
356 |
bytes2 := ExternalBytes new:30. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
357 |
bytes2 replaceBytesFrom:1 to:20 with:data startingAt:1. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
358 |
data replaceBytesFrom:2 to:20 with:bytes2 startingAt:1. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
359 |
bytes2 |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
360 |
|
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
361 |
|data bytes1 bytes2| |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
362 |
|
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
363 |
data := #[0 1 2 3 4 5 6 7 8 9 9 8 7 6 5 4 3 2 1 0]. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
364 |
bytes1 := ExternalBytes new:30. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
365 |
bytes2 := ExternalBytes new:30. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
366 |
bytes1 replaceBytesFrom:1 to:20 with:data startingAt:1. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
367 |
bytes2 atAllPut:99. |
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
368 |
bytes2 replaceBytesFrom:2 to:21 with:bytes1 startingAt:1. |
8908 | 369 |
bytes2 asByteArray |
7191
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
370 |
|
7192
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
371 |
|data1 bytes1 data2| |
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
372 |
|
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
373 |
data1 := #[0 1 2 3 4 5 6 7 8 9 9 8 7 6 5 4 3 2 1 0]. |
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
374 |
bytes1 := ExternalBytes new:30. |
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
375 |
bytes1 replaceBytesFrom:1 to:20 with:data1 startingAt:1. |
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
376 |
|
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
377 |
data2 := ByteArray new:30 withAll:99. |
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
378 |
data2 replaceBytesFrom:2 to:21 with:bytes1 startingAt:1. |
8908 | 379 |
data2 |
7192
3a388e746946
tuned the replaceBytes to/from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7191
diff
changeset
|
380 |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
381 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
382 |
! ! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
383 |
|
6459 | 384 |
!ExternalBytes class methodsFor:'initialization'! |
385 |
||
386 |
initialize |
|
387 |
Lobby isNil ifTrue:[ |
|
11854 | 388 |
Lobby := Registry new. |
6459 | 389 |
] |
390 |
! ! |
|
391 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
392 |
!ExternalBytes class methodsFor:'instance creation'! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
393 |
|
19512 | 394 |
address:anAddressInteger |
395 |
"return a new ExternalBytes object to access bytes starting at anAddressInteger. |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
396 |
The memory at anAddressInteger has been allocated elsewhere. |
19512 | 397 |
The size is not known, therefore byte accesses will NOT be checked for valid index. |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
398 |
Use this, if you get a pointer from some external source (such as a |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
399 |
C-callBack function) and you have to extract bytes from that. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
400 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
401 |
DANGER ALERT: this method allows very bad things to be done to the |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
402 |
system - use with GREAT care (better: do not use it)" |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
403 |
|
19512 | 404 |
^ self basicNew setAddress:anAddressInteger size:nil |
405 |
||
406 |
"Modified (comment): / 31-03-2016 / 11:05:07 / cg" |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
407 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
408 |
|
19512 | 409 |
address:anAddressInteger size:size |
410 |
"return a new ExternalBytes object to access bytes starting at anAddressInteger. |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
411 |
The memory at anAddressInteger has been allocated elsewhere. |
19512 | 412 |
The size is known, which allows byte accesses to be checked for valid index. |
8908 | 413 |
Use this, if you get a pointer to a structure from some external source |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
414 |
(such as a C-callBack function) and you have to extract things from that. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
415 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
416 |
DANGER ALERT: this method allows very bad things to be done to the |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
417 |
system - use with GREAT care (better: do not use it)" |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
418 |
|
19512 | 419 |
^ self basicNew setAddress:anAddressInteger size:size |
420 |
||
421 |
"Modified (comment): / 31-03-2016 / 11:04:27 / cg" |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
422 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
423 |
|
6459 | 424 |
new:numberOfBytes |
425 |
"allocate some memory usable for data; |
|
15398 | 426 |
the memory safe from being finalized by the garbage collector. |
6459 | 427 |
Return a corresponding ExternalBytes object or raise MallocFailure (if malloc fails). |
428 |
||
8908 | 429 |
Use this, if you have to pass a block of bytes to some |
6459 | 430 |
external destination (such as a C function) which does not copy the |
431 |
data, but instead keeps a reference to it. For example, many functions |
|
432 |
which expect strings simply keep a ref to the passed string - for those, |
|
433 |
an ST/X string-pointer is not the right thing to pass, since ST/X objects |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
434 |
may change their address. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
435 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
436 |
DANGER ALERT: the memory is NOT automatically freed until it is either |
18653 | 437 |
MANUALLY freed (see #free) or the returned externalBytes object |
438 |
is unprotected or the classes releaseAllMemory method is called." |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
439 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
440 |
|newInst| |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
441 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
442 |
newInst := self unprotectedNew:numberOfBytes. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
443 |
newInst protectFromGC. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
444 |
^ newInst |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
445 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
446 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
447 |
|bytes| |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
448 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
449 |
bytes := ExternalBytes new:100. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
450 |
bytes wordAt:1 put:1. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
451 |
bytes doubleWordAt:3 put:16r12345678. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
452 |
bytes inspect |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
453 |
" |
6459 | 454 |
! |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
455 |
|
10925 | 456 |
newNullTerminatedFromString:aString |
19422 | 457 |
"allocate a null terminated string containing the chars of aString" |
458 |
||
459 |
|nChars extBytes| |
|
460 |
||
461 |
nChars := aString size. |
|
462 |
self assert:(aString bitsPerCharacter == 8). |
|
463 |
||
464 |
extBytes := self new:nChars+1. |
|
465 |
extBytes replaceBytesFrom:1 to:nChars with:aString startingAt:1. |
|
466 |
extBytes at:nChars+1 put:0. |
|
467 |
^ extBytes |
|
468 |
! |
|
469 |
||
470 |
newNullTerminatedFromWideString:aString |
|
19512 | 471 |
"allocate a null terminated wide string containing the U16-chars of aString" |
19422 | 472 |
|
473 |
|nChars extBytes| |
|
474 |
||
475 |
nChars := aString size. |
|
476 |
self assert:(aString bitsPerCharacter <= 16). |
|
477 |
||
478 |
extBytes := self new:((nChars+1)*2). |
|
479 |
1 to:nChars do:[:i | |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
480 |
extBytes unsignedInt16At:(i*2) put:(aString at:i) codePoint. |
19422 | 481 |
]. |
482 |
extBytes unsignedInt16At:((nChars+1)*2) put:0. |
|
483 |
^ extBytes |
|
19512 | 484 |
|
485 |
"Modified (comment): / 31-03-2016 / 11:05:37 / cg" |
|
10925 | 486 |
! |
487 |
||
6459 | 488 |
unprotectedNew:numberOfBytes |
8908 | 489 |
"allocate some memory usable for data; |
15398 | 490 |
the memory is under the control of the garbage collector (i.e. the instance will |
491 |
be finalized and the malloc'd memory will be freed, if the instance goes away). |
|
6459 | 492 |
Return a corresponding ExternalBytes object or raise MallocFailure (if malloc fails). |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
493 |
|
6459 | 494 |
DANGER ALERT: the memory block as allocated will be automatically freed |
18653 | 495 |
as soon as the reference to the returned externalBytes object |
496 |
is gone (by the next garbage collect). |
|
497 |
If the memory has been passed to a C-function which |
|
498 |
remembers this pointer, bad things may happen ...." |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
499 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
500 |
|newInst| |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
501 |
|
6444 | 502 |
newInst := self basicNew allocateBytes:numberOfBytes. |
9388 | 503 |
newInst registerForFinalization. |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
504 |
^ newInst |
6444 | 505 |
|
506 |
" |
|
507 |
|bytes| |
|
508 |
||
509 |
bytes := ExternalBytes unprotectedNew:100. |
|
510 |
bytes wordAt:1 put:1. |
|
511 |
bytes doubleWordAt:3 put:16r12345678. |
|
512 |
bytes inspect |
|
513 |
" |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
514 |
! ! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
515 |
|
6459 | 516 |
!ExternalBytes class methodsFor:'instance release'! |
517 |
||
518 |
releaseAllMemory |
|
519 |
AllocatedInstances := nil |
|
520 |
" |
|
521 |
... the next GC will get 'em |
|
522 |
" |
|
523 |
! ! |
|
524 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
525 |
!ExternalBytes class methodsFor:'malloc debug'! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
526 |
|
6459 | 527 |
dumpMallocChunks |
528 |
%{ /* NOCONTEXT */ |
|
529 |
struct mallocList *entry; |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
530 |
|
6459 | 531 |
for (entry = mallocList; entry; entry=entry->next) { |
14632 | 532 |
console_printf(" %"_lx_" (%d)\n", (INT)(entry->chunk), entry->size); |
6459 | 533 |
} |
534 |
%} |
|
3321 | 535 |
" |
6459 | 536 |
self dumpMallocChunks |
3321 | 537 |
" |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
538 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
539 |
|
6459 | 540 |
freeAllMallocChunks |
541 |
"free all stx_malloc'd memory. Be careful, this does no validation at all; |
|
542 |
It simply walks through all chunks and frees them unconditionally. |
|
543 |
This may be helpful during debugging memory-leaks, to release memory which |
|
544 |
was not correctly freed by C-code. Howeve, only memory which was allocated |
|
545 |
by __stx_malloc() is freed here - so you better compile your primitive code with |
|
546 |
malloc redefined to stx_malloc. |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
547 |
Also, mallocDebug has to be on to do this." |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
548 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
549 |
"first free my own memory ..." |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
550 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
551 |
self releaseAllMemory. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
552 |
ObjectMemory garbageCollect. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
553 |
%{ |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
554 |
struct mallocList *entry; |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
555 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
556 |
while ((entry = mallocList) != (struct mallocList *)0) { |
13704 | 557 |
if (@global(TraceMalloc) == true ) { |
14632 | 558 |
console_printf("ExternalBytes [info]: **** forced free of %"_lx_" (%d)\n", (INT)entry->chunk, entry->size); |
13704 | 559 |
} |
560 |
__stx_free(entry->chunk); |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
561 |
} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
562 |
%} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
563 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
564 |
|
6459 | 565 |
mallocDebug:aBoolean |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
566 |
DebugMalloc := aBoolean |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
567 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
568 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
569 |
ExternalBytes mallocDebug:true |
8908 | 570 |
ExternalBytes mallocDebug:false |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
571 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
572 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
573 |
|
6459 | 574 |
mallocStatistics |
575 |
%{ |
|
576 |
__stx_mallocStatistics(); |
|
577 |
%} |
|
578 |
" |
|
579 |
self mallocStatistics |
|
3486 | 580 |
" |
581 |
! |
|
582 |
||
6459 | 583 |
mallocTrace:aBoolean |
584 |
TraceMalloc := aBoolean |
|
585 |
||
586 |
" |
|
587 |
ExternalBytes mallocTrace:true |
|
588 |
ExternalBytes mallocTrace:false |
|
589 |
" |
|
590 |
! |
|
591 |
||
592 |
numberOfAllocatedChunks |
|
593 |
%{ /* NOCONTEXT */ |
|
8913 | 594 |
RETURN ( __mkSmallInteger(mallocCount) ); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
595 |
%} |
3321 | 596 |
" |
597 |
self numberOfAllocatedChunks |
|
598 |
" |
|
6459 | 599 |
! ! |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
600 |
|
6459 | 601 |
!ExternalBytes class methodsFor:'queries'! |
602 |
||
21053 | 603 |
charTypeIsSigned |
604 |
"return true, if the machine's native chars are signed" |
|
605 |
||
606 |
%{ /* NOCONTEXT */ |
|
607 |
char c; |
|
608 |
||
609 |
c = (char)128; |
|
610 |
RETURN ( (int)c < 0 ? true : false ); |
|
611 |
%} |
|
612 |
" |
|
613 |
ExternalBytes charTypeIsSigned |
|
614 |
" |
|
615 |
! |
|
616 |
||
18580 | 617 |
doubleAlignment |
618 |
"return the alignement of longs in structs and unions" |
|
619 |
||
620 |
%{ /* NOCONTEXT */ |
|
621 |
struct { |
|
18653 | 622 |
char c; |
623 |
double d; |
|
18580 | 624 |
} dummy; |
18582 | 625 |
RETURN (__mkSmallInteger( (char *)&dummy.d - (char *)&dummy.c )); |
626 |
%} |
|
627 |
" |
|
628 |
ExternalBytes doubleAlignment |
|
629 |
" |
|
630 |
! |
|
631 |
||
18607 | 632 |
isBuiltInClass |
633 |
"return true if this class is known by the run-time-system. |
|
634 |
Here, true is returned." |
|
635 |
||
636 |
^ self == ExternalBytes |
|
637 |
||
638 |
"Modified: / 11.6.1998 / 17:12:51 / cg" |
|
639 |
! |
|
640 |
||
18580 | 641 |
longAlignment |
642 |
"return the alignement of longs in structs and unions" |
|
643 |
||
644 |
%{ /* NOCONTEXT */ |
|
645 |
struct { |
|
18653 | 646 |
char c; |
647 |
long l; |
|
18580 | 648 |
} dummy; |
18582 | 649 |
RETURN (__mkSmallInteger( (char *)&dummy.l - (char *)&dummy.c )); |
18580 | 650 |
%} |
651 |
" |
|
652 |
ExternalBytes longAlignment |
|
653 |
" |
|
654 |
! |
|
655 |
||
6459 | 656 |
sizeofDouble |
657 |
"return the number of bytes used by the machines native doubles" |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
658 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
659 |
%{ /* NOCONTEXT */ |
8913 | 660 |
RETURN (__mkSmallInteger( sizeof(double))); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
661 |
%} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
662 |
" |
8908 | 663 |
ExternalBytes sizeofDouble |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
664 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
665 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
666 |
|
20489 | 667 |
sizeofEnums |
668 |
"return the number of bytes used by the machine's native enums. |
|
669 |
Be aware, that this can be adjusted in some compilers via the __packed__ attribute; |
|
670 |
So better double check..." |
|
671 |
||
672 |
%{ /* NOCONTEXT */ |
|
673 |
enum foo { bla1, bla2 } foo; |
|
674 |
RETURN (__mkSmallInteger( sizeof(foo))); |
|
675 |
%} |
|
676 |
" |
|
677 |
ExternalBytes sizeofEnums |
|
678 |
" |
|
679 |
! |
|
680 |
||
6459 | 681 |
sizeofFloat |
17627 | 682 |
"return the number of bytes used by the machine's native floats" |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
683 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
684 |
%{ /* NOCONTEXT */ |
8913 | 685 |
RETURN (__mkSmallInteger( sizeof(float))); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
686 |
%} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
687 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
688 |
ExternalBytes sizeofFloat |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
689 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
690 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
691 |
|
6459 | 692 |
sizeofInt |
17627 | 693 |
"return the number of bytes used by the machine's native integer" |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
694 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
695 |
%{ /* NOCONTEXT */ |
8913 | 696 |
RETURN (__mkSmallInteger( sizeof(int))); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
697 |
%} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
698 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
699 |
ExternalBytes sizeofInt |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
700 |
" |
6459 | 701 |
! |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
702 |
|
6459 | 703 |
sizeofLong |
17627 | 704 |
"return the number of bytes used by the machine's native longs" |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
705 |
|
6459 | 706 |
%{ /* NOCONTEXT */ |
8913 | 707 |
RETURN (__mkSmallInteger( sizeof(long))); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
708 |
%} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
709 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
710 |
ExternalBytes sizeofLong |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
711 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
712 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
713 |
|
17627 | 714 |
sizeofLongDouble |
715 |
"return the number of bytes used by the machine's native longdouble. |
|
716 |
If the machine does not support them, return nil." |
|
717 |
||
718 |
%{ /* NOCONTEXT */ |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
719 |
#if defined(__GNUC__) || defined(__CLANG__) || defined(__win32__) |
17627 | 720 |
RETURN (__mkSmallInteger( sizeof(long double))); |
721 |
#endif |
|
722 |
%}. |
|
723 |
^ nil |
|
724 |
||
725 |
" |
|
18653 | 726 |
ExternalBytes sizeofLongDouble |
17627 | 727 |
" |
728 |
! |
|
729 |
||
730 |
sizeofLongLong |
|
731 |
"return the number of bytes used by the machine's native longlongs. |
|
732 |
If the machine does not support them, return nil." |
|
733 |
||
734 |
%{ /* NOCONTEXT */ |
|
735 |
#ifdef HAS_LONGLONG |
|
736 |
RETURN (__mkSmallInteger( sizeof(long long))); |
|
737 |
#endif |
|
738 |
%}. |
|
739 |
^ nil |
|
740 |
||
741 |
" |
|
742 |
ExternalBytes sizeofLongLong |
|
743 |
" |
|
744 |
! |
|
745 |
||
18878 | 746 |
sizeofNativeInt |
747 |
"return the number of bytes used by the machine's SmallInteger native values" |
|
748 |
||
749 |
%{ /* NOCONTEXT */ |
|
750 |
RETURN (__mkSmallInteger( sizeof(INT))); |
|
751 |
%} |
|
752 |
" |
|
753 |
ExternalBytes sizeofNativeInt |
|
754 |
" |
|
755 |
! |
|
756 |
||
6459 | 757 |
sizeofPointer |
17627 | 758 |
"return the number of bytes used by the machine's native pointer" |
6459 | 759 |
|
760 |
%{ /* NOCONTEXT */ |
|
8913 | 761 |
RETURN (__mkSmallInteger( sizeof(char *))); |
6459 | 762 |
%} |
763 |
" |
|
764 |
ExternalBytes sizeofPointer |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
765 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
766 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
767 |
|
6459 | 768 |
sizeofShort |
17627 | 769 |
"return the number of bytes used by the machine's native short" |
6459 | 770 |
|
771 |
%{ /* NOCONTEXT */ |
|
8913 | 772 |
RETURN (__mkSmallInteger( sizeof(short))); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
773 |
%} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
774 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
775 |
ExternalBytes sizeofShort |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
776 |
" |
6459 | 777 |
! ! |
778 |
||
779 |
!ExternalBytes methodsFor:'accessing'! |
|
780 |
||
781 |
address |
|
782 |
"return the start address as an integer" |
|
783 |
||
784 |
%{ /* NOCONTEXT */ |
|
785 |
||
11629 | 786 |
if (__INST(address_) != nil) { |
11854 | 787 |
unsigned INT addr; |
6459 | 788 |
|
11854 | 789 |
addr = (unsigned INT)__INST(address_); |
790 |
RETURN ( __MKUINT(addr)); |
|
6459 | 791 |
} |
792 |
%}. |
|
793 |
^ nil |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
794 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
795 |
|
6459 | 796 |
basicAt:index |
797 |
"return the byte at index, anInteger; |
|
798 |
Indices are 1-based, therefore |
|
799 |
this is the byte at (address + index - 1)" |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
800 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
801 |
%{ /* NOCONTEXT */ |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
802 |
|
1822 | 803 |
unsigned char *cp = (unsigned char *)(__INST(address_)); |
23102
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
804 |
INT indx; |
1997 | 805 |
OBJ sz; |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
806 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
807 |
if (cp && __isSmallInteger(index)) { |
23102
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
808 |
indx = __intVal(index); |
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
809 |
if (indx > 0) { |
6242 | 810 |
if (((sz = __INST(size)) == nil) |
23102
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
811 |
|| (__intVal(sz) >= indx)) { |
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
812 |
cp = cp + indx - 1; |
8913 | 813 |
RETURN ( __mkSmallInteger((*cp)) ); |
6242 | 814 |
} |
815 |
} |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
816 |
} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
817 |
%}. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
818 |
(size notNil and:[self address notNil]) ifTrue:[ |
6242 | 819 |
^ self subscriptBoundsError:index |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
820 |
]. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
821 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
822 |
invalid index or unallocated |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
823 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
824 |
self primitiveFailed |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
825 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
826 |
|
6459 | 827 |
basicAt:index put:value |
828 |
"set the byte at index, anInteger to value which must be 0..255. |
|
829 |
Returns value (sigh). |
|
830 |
Indices are 1-based, therefore |
|
831 |
this is the byte at (address + index - 1)" |
|
832 |
||
833 |
%{ /* NOCONTEXT */ |
|
834 |
||
835 |
unsigned char *cp = (unsigned char *)(__INST(address_)); |
|
836 |
int val; |
|
23102
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
837 |
INT indx; |
6459 | 838 |
OBJ sz; |
839 |
||
840 |
if (__isSmallInteger(value)) { |
|
841 |
val = __smallIntegerVal(value); |
|
8908 | 842 |
} else if (__isCharacter(value)) { |
15262
5047292c9107
all stx macros begin with double underline (eg. __qClass instead of _qClass)
Claus Gittinger <cg@exept.de>
parents:
15003
diff
changeset
|
843 |
val = __smallIntegerVal(__characterVal(value)); |
6459 | 844 |
} else |
845 |
goto badArg; |
|
846 |
||
847 |
if (cp && __isSmallInteger(index)) { |
|
23102
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
848 |
indx = __intVal(index); |
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
849 |
if (indx > 0) { |
6445 | 850 |
if (((sz = __INST(size)) == nil) |
23102
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
851 |
|| (__intVal(sz) >= indx)) { |
6445 | 852 |
if ((val & ~0xFF) == 0) /* i.e. (val >= 0) && (val <= 255) */ { |
23102
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
853 |
cp[indx-1] = val; |
6445 | 854 |
RETURN ( value ); |
855 |
} |
|
856 |
} |
|
857 |
} |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
858 |
} |
6302
32ede83e77e5
allow for character arg in #at:put:
Claus Gittinger <cg@exept.de>
parents:
6242
diff
changeset
|
859 |
|
32ede83e77e5
allow for character arg in #at:put:
Claus Gittinger <cg@exept.de>
parents:
6242
diff
changeset
|
860 |
badArg: ; |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
861 |
%}. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
862 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
863 |
(size notNil and:[self address notNil]) ifTrue:[ |
6445 | 864 |
(index between:1 and:size) ifTrue:[ |
865 |
^ ElementOutOfBoundsSignal raise |
|
866 |
]. |
|
867 |
^ self subscriptBoundsError:index |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
868 |
]. |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
869 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
870 |
invalid index, invalid value or unallocated |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
871 |
" |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
872 |
self primitiveFailed |
1220 | 873 |
|
874 |
"Modified: 19.4.1996 / 11:15:05 / cg" |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
875 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
876 |
|
6459 | 877 |
byteAt:index |
878 |
"return the unsigned byte at index, anInteger. |
|
879 |
Indices are 1-based, therefore |
|
880 |
this is the byte at (address + index - 1)" |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
881 |
|
6459 | 882 |
^ self basicAt:index |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
883 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
884 |
|
6459 | 885 |
byteAt:index put:aByteValuedInteger |
886 |
"set the byte at index. |
|
887 |
Indices are 1-based, therefore |
|
888 |
this is the byte at (address + index - 1)" |
|
889 |
||
890 |
^ self basicAt:index put:aByteValuedInteger |
|
891 |
! |
|
892 |
||
13196
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
893 |
copyCStringFromHeap |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
894 |
"fetch a 0-terminated string from my pointed-to address" |
6459 | 895 |
|
12594
d7267a747c2f
changed: #copyCStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
11854
diff
changeset
|
896 |
|idx byte s| |
11739 | 897 |
|
12594
d7267a747c2f
changed: #copyCStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
11854
diff
changeset
|
898 |
idx := 1. |
20481 | 899 |
s := WriteStream on:''. |
12594
d7267a747c2f
changed: #copyCStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
11854
diff
changeset
|
900 |
[(byte := self at:idx) ~~ 0] whileTrue:[ |
20481 | 901 |
s nextPut:(Character value:byte). |
902 |
idx := idx + 1. |
|
11739 | 903 |
]. |
13196
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
904 |
^ s contents |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
905 |
! |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
906 |
|
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
907 |
copyUnicodeStringFromHeap |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
908 |
"fetch a 0-terminated wide-string from my pointed-to address" |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
909 |
|
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
910 |
|idx word s| |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
911 |
|
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
912 |
idx := 1. |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
913 |
s := WriteStream on:Unicode16String new. |
19419 | 914 |
[(word := self unsignedInt16At:idx) ~~ 0] whileTrue:[ |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
915 |
s nextPut:(Character value:word). |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
916 |
idx := idx + 2. |
13196
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
917 |
]. |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
918 |
^ s contents |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
919 |
! |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
920 |
|
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
921 |
instVarAt:index |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
922 |
"redefined to suppress direct access to my address, which is a non-object" |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
923 |
|
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
924 |
index == 1 ifTrue:[^ self address]. |
a8e595628fb5
added: #copyUnicodeStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
13076
diff
changeset
|
925 |
^ super instVarAt:index |
11739 | 926 |
! ! |
927 |
||
6491
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
928 |
!ExternalBytes methodsFor:'converting'! |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
929 |
|
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
930 |
asExternalAddress |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
931 |
"return the start address as an external address" |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
932 |
|
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
933 |
%{ /* NOCONTEXT */ |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
934 |
|
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
935 |
RETURN(__MKEXTERNALADDRESS(__INST(address_))); |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
936 |
%}. |
19419 | 937 |
self primitiveFailed |
6491
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
938 |
! |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
939 |
|
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
940 |
asExternalBytes |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
941 |
|
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
942 |
^ self |
20138 | 943 |
! |
944 |
||
945 |
asString |
|
946 |
"speed up string conversions" |
|
947 |
||
948 |
|size| |
|
949 |
||
950 |
self class == ExternalBytes ifTrue:[ |
|
951 |
size := self size. |
|
952 |
^ (String uninitializedNew:size) replaceBytesFrom:1 to:size with:self startingAt:1. |
|
953 |
]. |
|
954 |
^ super asString. |
|
955 |
||
956 |
" |
|
957 |
#[16r41 16r42 16r43] asExternalBytes asString |
|
958 |
" |
|
6491
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
959 |
! ! |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
960 |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
961 |
!ExternalBytes methodsFor:'filling & replacing'! |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
962 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
963 |
replaceBytesFrom:start to:stop with:aCollection startingAt:repStart |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
964 |
"replace elements from another collection, which must be a ByteArray- |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
965 |
like collection. |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
966 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
967 |
Notice: This operation modifies the receiver, NOT a copy; |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
968 |
therefore the change may affect all others referencing the receiver." |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
969 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
970 |
%{ /* NOCONTEXT */ |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
971 |
|
23102
574962856f04
Issue #200: fixed `#basicAt:` / `#basicAt:put:` to work with objects bigger than 2GB
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
21088
diff
changeset
|
972 |
unsigned INT nIndex, repNIndex; |
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
973 |
int startIndex, stopIndex; |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
974 |
REGISTER unsigned char *src; |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
975 |
REGISTER int repStartIndex; |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
976 |
int repStopIndex, count; |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
977 |
REGISTER unsigned char *dst; |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
978 |
OBJ cls; |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
979 |
|
14076
5f68cf5ece9c
changed: #replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
13704
diff
changeset
|
980 |
if ((__isBytes(aCollection) || __isWords(aCollection) || __isExternalBytesLike(aCollection)) |
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
981 |
&& __bothSmallInteger(start, stop) |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
982 |
&& __isSmallInteger(repStart)) { |
14632 | 983 |
startIndex = __intVal(start) - 1; |
984 |
if (startIndex >= 0) { |
|
985 |
dst = (unsigned char *)__INST(address_) + startIndex; |
|
986 |
nIndex = __smallIntegerVal(__INST(size)); |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
987 |
|
14632 | 988 |
stopIndex = __intVal(stop) - 1; |
989 |
count = stopIndex - startIndex + 1; |
|
990 |
if (count == 0) { |
|
991 |
RETURN ( self ); |
|
992 |
} |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
993 |
|
14632 | 994 |
if ((count > 0) && (stopIndex < nIndex)) { |
995 |
repStartIndex = __intVal(repStart) - 1; |
|
996 |
if (repStartIndex >= 0) { |
|
997 |
if (__isExternalBytesLike(aCollection)) { |
|
998 |
OBJ sz; |
|
7191
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
999 |
|
14632 | 1000 |
src = __externalBytesVal(aCollection); |
1001 |
if (src == 0) goto fallBack; |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1002 |
|
14632 | 1003 |
sz = __externalBytesSize(aCollection); |
1004 |
if (__isSmallInteger(sz)) { |
|
1005 |
repNIndex = __smallIntegerVal(sz); |
|
1006 |
} else { |
|
1007 |
repNIndex = -1; /* unknown */ |
|
1008 |
} |
|
1009 |
src = src + repStartIndex; |
|
1010 |
} else { |
|
1011 |
repNIndex = __qSize(aCollection) - OHDR_SIZE; |
|
1012 |
src = __byteArrayVal(aCollection) + repStartIndex; |
|
1013 |
if ((cls = __qClass(aCollection)) != @global(ByteArray)) { |
|
1014 |
int nInst; |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1015 |
|
14632 | 1016 |
nInst = __OBJS2BYTES__(__intVal(__ClassInstPtr(cls)->c_ninstvars)); |
1017 |
src += nInst; |
|
1018 |
repNIndex -= nInst; |
|
1019 |
} |
|
1020 |
} |
|
7191
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
1021 |
|
14632 | 1022 |
repStopIndex = repStartIndex + (stopIndex - startIndex); |
1023 |
if (repStopIndex < repNIndex) { |
|
1024 |
if (aCollection == self) { |
|
1025 |
/* take care of overlapping copy */ |
|
1026 |
if (src < dst) { |
|
1027 |
/* must do a reverse copy */ |
|
1028 |
src += count; |
|
1029 |
dst += count; |
|
1030 |
while (count-- > 0) { |
|
1031 |
*--dst = *--src; |
|
1032 |
} |
|
1033 |
RETURN ( self ); |
|
1034 |
} |
|
1035 |
} |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1036 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1037 |
#ifdef memcpy4 |
14632 | 1038 |
if (((unsigned INT)src & 3) == ((unsigned INT)dst & 3)) { |
1039 |
int nW; |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1040 |
|
14632 | 1041 |
/* copy unaligned part */ |
1042 |
while (count && ((unsigned INT)src & 3)) { |
|
1043 |
*dst++ = *src++; |
|
1044 |
count--; |
|
1045 |
} |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1046 |
|
14632 | 1047 |
if (count > 0) { |
1048 |
/* copy aligned part */ |
|
1049 |
nW = count >> 2; |
|
1050 |
memcpy4(dst, src, nW); |
|
1051 |
if ((count = count & 3) != 0) { |
|
1052 |
/* copy any remaining part */ |
|
1053 |
src += (nW<<2); |
|
1054 |
dst += (nW<<2); |
|
1055 |
while (count--) { |
|
1056 |
*dst++ = *src++; |
|
1057 |
} |
|
1058 |
} |
|
1059 |
} |
|
1060 |
RETURN ( self ); |
|
1061 |
} |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1062 |
#else |
8901
824a89d0b5c7
alpha64 vs. POINTER_SIZE cleanup
Claus Gittinger <cg@exept.de>
parents:
8288
diff
changeset
|
1063 |
# if __POINTER_SIZE__ == 8 |
14632 | 1064 |
if (((unsigned INT)src & 7) == ((unsigned INT)dst & 7)) { |
1065 |
/* copy unaligned part */ |
|
1066 |
while (count && ((unsigned INT)src & 7)) { |
|
1067 |
*dst++ = *src++; |
|
1068 |
count--; |
|
1069 |
} |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1070 |
|
14632 | 1071 |
/* copy aligned part */ |
1072 |
while (count >= 8) { |
|
1073 |
((unsigned INT *)dst)[0] = ((unsigned INT *)src)[0]; |
|
1074 |
dst += 8; |
|
1075 |
src += 8; |
|
1076 |
count -= 8; |
|
1077 |
} |
|
1078 |
while (count--) { |
|
1079 |
*dst++ = *src++; |
|
1080 |
} |
|
1081 |
RETURN ( self ); |
|
1082 |
} |
|
8908 | 1083 |
# endif /* 64bit */ |
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1084 |
#endif /* memcpy4 */ |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1085 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1086 |
#ifdef FAST_MEMCPY |
14632 | 1087 |
memcpy(dst, src, count); |
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1088 |
#else |
8919 | 1089 |
# ifdef __UNROLL_LOOPS__ |
14632 | 1090 |
while (count >= 8) { |
1091 |
dst[0] = src[0]; dst[1] = src[1]; |
|
1092 |
dst[2] = src[2]; dst[3] = src[3]; |
|
1093 |
dst[4] = src[4]; dst[5] = src[5]; |
|
1094 |
dst[6] = src[6]; dst[7] = src[7]; |
|
1095 |
dst += 8; src += 8; |
|
1096 |
count -= 8; |
|
1097 |
} |
|
8919 | 1098 |
# endif /* __UNROLL_LOOPS__ */ |
14632 | 1099 |
while (count-- > 0) { |
1100 |
*dst++ = *src++; |
|
1101 |
} |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1102 |
#endif |
14632 | 1103 |
RETURN ( self ); |
1104 |
} |
|
1105 |
} |
|
1106 |
} |
|
1107 |
} |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1108 |
} |
7191
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
1109 |
fallBack: ; |
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1110 |
%}. |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1111 |
" |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1112 |
fall back for the error report if any index is invalid |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1113 |
" |
7191
82bddba980b6
tuned the replaceBytes from another externalBytes object case.
Claus Gittinger <cg@exept.de>
parents:
7184
diff
changeset
|
1114 |
^ super replaceBytesFrom:start to:stop with:aCollection startingAt:repStart |
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1115 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1116 |
" |
14125
6aec556d2bbf
comment changed: #replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
14080
diff
changeset
|
1117 |
((ExternalBytes unprotectedNew:16) |
14632 | 1118 |
replaceBytesFrom:1 to:8 |
1119 |
with:#[10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160] |
|
1120 |
startingAt:1) copy |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1121 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1122 |
(ExternalBytes unprotectedNew:16) |
14632 | 1123 |
replaceBytesFrom:3 to:10 |
1124 |
with:#[10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160] |
|
1125 |
startingAt:4 |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1126 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1127 |
(ExternalBytes unprotectedNew:16) |
14632 | 1128 |
replaceBytesFrom:3 to:4 |
1129 |
with:#[10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160] |
|
1130 |
startingAt:1 |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1131 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1132 |
(ExternalBytes unprotectedNew:16) |
14632 | 1133 |
replaceBytesFrom:0 to:9 |
1134 |
with:#[10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160] |
|
1135 |
startingAt:1 |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1136 |
|
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1137 |
(ExternalBytes unprotectedNew:16) |
14632 | 1138 |
replaceBytesFrom:1 to:10 |
1139 |
with:#[10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160] |
|
1140 |
startingAt:0 |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1141 |
" |
19168 | 1142 |
! |
1143 |
||
1144 |
replaceNullTerminatedFromString:aString |
|
1145 |
"replace elements from aString, and add a 0-byte at the end" |
|
1146 |
||
19169 | 1147 |
|nChars| |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1148 |
|
19169 | 1149 |
nChars := aString size. |
1150 |
self replaceBytesFrom:1 to:nChars with:aString startingAt:1. |
|
1151 |
self at:nChars+1 put:0. |
|
6483
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1152 |
! ! |
ec599166f169
replaceBytesFrom:to:with:startingAt:
Stefan Vogel <sv@exept.de>
parents:
6471
diff
changeset
|
1153 |
|
6444 | 1154 |
!ExternalBytes methodsFor:'finalization'! |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1155 |
|
6440
eb9cdc352a7c
Use #finalize instead of #disposed
Stefan Vogel <sv@exept.de>
parents:
6425
diff
changeset
|
1156 |
executor |
8908 | 1157 |
"redefined to return a lightweight copy |
7184 | 1158 |
- all we need is the memory handle and the size." |
6491
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
1159 |
|
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
1160 |
%{ /* NOCONTEXT */ |
6440
eb9cdc352a7c
Use #finalize instead of #disposed
Stefan Vogel <sv@exept.de>
parents:
6425
diff
changeset
|
1161 |
|
7386
0996b933cbf1
Need __STORE() when assigning class
Stefan Vogel <sv@exept.de>
parents:
7257
diff
changeset
|
1162 |
OBJ theCopy, cls; |
7184 | 1163 |
|
7855
27f64d1beaa1
Have to protect self, otherwise bad things happen in the VM.
Stefan Vogel <sv@exept.de>
parents:
7386
diff
changeset
|
1164 |
__PROTECT__(self); |
7184 | 1165 |
theCopy = __MKEXTERNALBYTES_N(__INST(address_), __smallIntegerVal(__INST(size))); |
7855
27f64d1beaa1
Have to protect self, otherwise bad things happen in the VM.
Stefan Vogel <sv@exept.de>
parents:
7386
diff
changeset
|
1166 |
__UNPROTECT__(self); |
7386
0996b933cbf1
Need __STORE() when assigning class
Stefan Vogel <sv@exept.de>
parents:
7257
diff
changeset
|
1167 |
__InstPtr(theCopy)->o_class = cls = __InstPtr(self)->o_class; |
0996b933cbf1
Need __STORE() when assigning class
Stefan Vogel <sv@exept.de>
parents:
7257
diff
changeset
|
1168 |
__STORE(theCopy, cls); |
7184 | 1169 |
RETURN (theCopy); |
6491
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
1170 |
%} |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
1171 |
|
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
1172 |
" |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
1173 |
(ExternalBytes unprotectedNew:10) executor |
6976d9b69e01
Conversion between ExternalBytes and ExternalAddress
Stefan Vogel <sv@exept.de>
parents:
6484
diff
changeset
|
1174 |
" |
6440
eb9cdc352a7c
Use #finalize instead of #disposed
Stefan Vogel <sv@exept.de>
parents:
6425
diff
changeset
|
1175 |
! |
eb9cdc352a7c
Use #finalize instead of #disposed
Stefan Vogel <sv@exept.de>
parents:
6425
diff
changeset
|
1176 |
|
6462
245e99c09df0
Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents:
6459
diff
changeset
|
1177 |
finalizationLobby |
245e99c09df0
Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents:
6459
diff
changeset
|
1178 |
"answer the registry used for finalization. |
245e99c09df0
Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents:
6459
diff
changeset
|
1179 |
ExternalBytes have their own Registry" |
245e99c09df0
Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents:
6459
diff
changeset
|
1180 |
|
245e99c09df0
Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents:
6459
diff
changeset
|
1181 |
^ Lobby |
245e99c09df0
Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents:
6459
diff
changeset
|
1182 |
! |
245e99c09df0
Allow #registerForFinalization for classes defining their own Lobby.
Stefan Vogel <sv@exept.de>
parents:
6459
diff
changeset
|
1183 |
|
6440
eb9cdc352a7c
Use #finalize instead of #disposed
Stefan Vogel <sv@exept.de>
parents:
6425
diff
changeset
|
1184 |
finalize |
2779 | 1185 |
"some ExternalBytes object was finalized; |
1186 |
free the associated heap memory with it" |
|
1187 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1188 |
%{ /* NOCONTEXT */ |
19376 | 1189 |
char *mem = (char *)__INST(address_); |
6457 | 1190 |
if (mem && (OBJ)mem != nil) { |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1191 |
__stx_free(mem); |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1192 |
} |
1133 | 1193 |
__INST(address_) = __INST(size) = nil; |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1194 |
%} |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1195 |
! ! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1196 |
|
6444 | 1197 |
!ExternalBytes methodsFor:'freeing'! |
1198 |
||
6459 | 1199 |
free |
1200 |
"free a previously allocated piece of memory - be very careful, there |
|
1201 |
are no checks done here. All dangers you usually have with malloc/free |
|
1202 |
are present here ..." |
|
1203 |
||
1204 |
"at least, we check for double freeing the same chunk" |
|
1205 |
self address isNil ifTrue:[ |
|
1206 |
self error:'freeing memory twice'. |
|
1207 |
^ self |
|
1208 |
]. |
|
1209 |
Lobby unregister:self. |
|
1210 |
self finalize. "/ does what we need here .. |
|
1211 |
self unprotectFromGC |
|
7184 | 1212 |
! |
1213 |
||
1214 |
register |
|
1215 |
"register the receiver to be automatically finalized by the GC" |
|
1216 |
||
1217 |
Lobby register:self. |
|
6444 | 1218 |
! ! |
1219 |
||
20188 | 1220 |
!ExternalBytes methodsFor:'pointer arithmetic'! |
6443 | 1221 |
|
6502
87f587d1542e
rename #from:to to #referenceToBytesFrom:to
Stefan Vogel <sv@exept.de>
parents:
6491
diff
changeset
|
1222 |
referenceToBytesFrom:start to:stop |
6459 | 1223 |
"answer a new ExternalBytes referencing a range within the receiver. |
6502
87f587d1542e
rename #from:to to #referenceToBytesFrom:to
Stefan Vogel <sv@exept.de>
parents:
6491
diff
changeset
|
1224 |
BE CAREFUL: after the receiver has been freed, the new ExternalBytes |
6459 | 1225 |
contents is undefined" |
1226 |
||
8908 | 1227 |
%{ /* NOCONTEXT */ |
6459 | 1228 |
|
6471 | 1229 |
char *addr; |
6459 | 1230 |
int size; |
1231 |
int __start, __stop; |
|
1232 |
||
1233 |
if (__bothSmallInteger(start, stop) && __INST(address_) != nil) { |
|
6503 | 1234 |
__start = __smallIntegerVal(start); |
1235 |
__stop = __smallIntegerVal(stop); |
|
1236 |
if (__start > 0 && __start <= __stop && __stop <= __smallIntegerVal(__INST(size))) { |
|
1237 |
addr = (char *)(__INST(address_)) + (__start - 1); |
|
1238 |
size = __stop - __start + 1; |
|
1239 |
RETURN( __MKEXTERNALBYTES_N(addr, size) ); |
|
1240 |
} |
|
6459 | 1241 |
} |
1242 |
%}. |
|
1243 |
^ self primitiveFailed |
|
6458 | 1244 |
! ! |
6443 | 1245 |
|
6458 | 1246 |
!ExternalBytes methodsFor:'printing & storing'! |
6443 | 1247 |
|
13076
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1248 |
displayOn:aGCOrStream |
6459 | 1249 |
"return a printed representation of the receiver for displaying" |
1250 |
||
13076
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1251 |
|addr| |
6443 | 1252 |
|
13076
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1253 |
"/ what a kludge - Dolphin and Squeak mean: printOn: a stream; |
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1254 |
"/ ST/X (and some old ST80's) mean: draw-yourself on a GC. |
16739 | 1255 |
(aGCOrStream isStream) ifFalse:[ |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1256 |
^ super displayOn:aGCOrStream |
13076
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1257 |
]. |
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1258 |
|
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1259 |
aGCOrStream nextPutAll:self className. |
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1260 |
addr := self address. |
29b8a558bcf2
Implement display with #displayOn: instead of #displayString
Stefan Vogel <sv@exept.de>
parents:
12864
diff
changeset
|
1261 |
addr isNil ifTrue:[ |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1262 |
aGCOrStream nextPutAll:'[free]'. |
6459 | 1263 |
] ifFalse:[ |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1264 |
size notNil ifTrue:[ |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1265 |
aGCOrStream nextPutAll:'[sz:'. |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1266 |
size printOn:aGCOrStream. |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1267 |
aGCOrStream space. |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1268 |
] ifFalse:[ |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1269 |
aGCOrStream nextPut:$[. |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1270 |
]. |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1271 |
aGCOrStream nextPutAll:'@'. |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1272 |
addr printOn:aGCOrStream base:16. |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1273 |
aGCOrStream nextPut:$]. |
6459 | 1274 |
]. |
1275 |
||
18829 | 1276 |
" |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1277 |
self new printString |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1278 |
(self new:5) displayString |
18829 | 1279 |
" |
1280 |
||
1281 |
||
6459 | 1282 |
"Modified: / 24.2.2000 / 19:02:19 / cg" |
6458 | 1283 |
! ! |
1284 |
||
7257 | 1285 |
!ExternalBytes methodsFor:'private-accessing'! |
6458 | 1286 |
|
9388 | 1287 |
invalidateReference |
1288 |
"clear the start address and size" |
|
1289 |
||
1290 |
%{ /* NOCONTEXT */ |
|
1291 |
__INST(address_) = nil; |
|
1292 |
__INST(size) = nil; |
|
1293 |
%} |
|
1294 |
! |
|
1295 |
||
8908 | 1296 |
setAddress:aNumber size:sz |
6459 | 1297 |
"set the start address and size" |
1298 |
||
1299 |
%{ /* NOCONTEXT */ |
|
1300 |
if (__INST(address_) == nil) { |
|
1301 |
if (aNumber == nil) { |
|
1302 |
__INST(address_) = nil; |
|
1303 |
} else { |
|
1304 |
if (__isSmallInteger(aNumber)) { |
|
1305 |
__INST(address_) = (OBJ) __intVal(aNumber); |
|
1306 |
} else if(__isInteger(aNumber)) { |
|
1307 |
__INST(address_) = (OBJ) __unsignedLongIntVal(aNumber); |
|
1308 |
} else if(__isExternalAddress(aNumber)) { |
|
1309 |
__INST(address_) = __externalAddressVal(aNumber); |
|
1310 |
} |
|
6445 | 1311 |
} |
6459 | 1312 |
__INST(size) = sz; |
1313 |
RETURN (self); |
|
6443 | 1314 |
} |
1315 |
%}. |
|
6459 | 1316 |
^ self error:'cannot change address' |
8288 | 1317 |
! |
1318 |
||
8908 | 1319 |
setSize:sz |
8288 | 1320 |
"set the size - warning: dangerous if wrong" |
1321 |
||
1322 |
size := sz |
|
6443 | 1323 |
! ! |
1324 |
||
7257 | 1325 |
!ExternalBytes methodsFor:'private-allocation'! |
6444 | 1326 |
|
1327 |
allocateBytes:numberOfBytes |
|
11854 | 1328 |
"allocate (malloc) numberOfBytes; if doClear is true, the allocated memory is cleared. |
1329 |
Fail if already allocated. |
|
1330 |
Raise MallocFailure if malloc fails to allocate enough memory" |
|
1331 |
||
1332 |
^ self allocateBytes:numberOfBytes clear:true |
|
1333 |
! |
|
1334 |
||
1335 |
allocateBytes:numberOfBytes clear:doClear |
|
1336 |
"allocate (malloc) numberOfBytes; if doClear is true, the allocated memory is cleared. |
|
6444 | 1337 |
Fail if already allocated. |
1338 |
Raise MallocFailure if malloc fails to allocate enough memory" |
|
1339 |
||
1340 |
|mallocFailure| |
|
1341 |
||
6457 | 1342 |
%{ |
6444 | 1343 |
/* |
8908 | 1344 |
* Fail if already allocated |
6444 | 1345 |
*/ |
1346 |
if (__INST(address_) == nil && __isSmallInteger(numberOfBytes)) { |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1347 |
INT nBytes = __smallIntegerVal(numberOfBytes); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1348 |
if (nBytes > 0) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1349 |
char *space = __stx_malloc(nBytes); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1350 |
if (space) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1351 |
if (doClear == true) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1352 |
bzero(space, nBytes); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1353 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1354 |
__INST(address_) = (OBJ)space; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1355 |
__INST(size) = numberOfBytes; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1356 |
RETURN(self); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1357 |
} else { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1358 |
mallocFailure = true; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1359 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1360 |
} |
6444 | 1361 |
} |
1362 |
%}. |
|
1363 |
mallocFailure == true ifTrue:[ |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1364 |
^ MallocFailure raiseRequestWith:numberOfBytes. |
6444 | 1365 |
] ifFalse:[ |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1366 |
self primitiveFailed. |
6444 | 1367 |
]. |
1368 |
! ! |
|
1369 |
||
5557 | 1370 |
!ExternalBytes methodsFor:'queries'! |
1371 |
||
6459 | 1372 |
basicSize |
1373 |
"we do not know how many bytes are valid" |
|
5557 | 1374 |
|
6459 | 1375 |
size isNil ifTrue:[^ 0]. |
1376 |
^ size |
|
6443 | 1377 |
! |
1378 |
||
18607 | 1379 |
containsNon7BitAscii |
1380 |
"return true, if any byte in the receiver has the 7th bit on. |
|
1381 |
This my look as a too specific operation to be put here, |
|
1382 |
put it is very helpful for UTF8 string reading (Java class reader), |
|
1383 |
to quickly determine, if UTF8 decoding is needed or not. |
|
1384 |
As most strings in a class file are in fact only containing 7bit ascii, |
|
1385 |
this should speedup class file reading considerably" |
|
1386 |
||
1387 |
%{ /* NOCONTEXT */ |
|
18653 | 1388 |
unsigned char *cp = (unsigned char *)(__INST(address_)); |
18607 | 1389 |
unsigned int size = __intVal(__INST(size)); |
1390 |
unsigned char *endP; |
|
1391 |
||
19328 | 1392 |
if (cp == NULL || size == 0) { |
18653 | 1393 |
RETURN(false); |
18607 | 1394 |
} |
1395 |
||
1396 |
endP = cp + size; |
|
1397 |
#if __POINTER_SIZE__ == 8 |
|
1398 |
while (cp+8 < endP) { |
|
18653 | 1399 |
if ( ((unsigned INT *)cp)[0] & 0x8080808080808080) RETURN( true ); |
1400 |
cp += 8; |
|
18607 | 1401 |
} |
1402 |
#endif |
|
1403 |
while (cp+4 < endP) { |
|
18653 | 1404 |
if ( ((unsigned int *)cp)[0] & 0x80808080) RETURN( true ); |
1405 |
cp += 4; |
|
18607 | 1406 |
} |
1407 |
while (cp < endP) { |
|
18653 | 1408 |
if (*cp++ & 0x80) RETURN( true ); |
18607 | 1409 |
} |
1410 |
RETURN ( false ); |
|
1411 |
%} |
|
1412 |
. |
|
1413 |
^ self contains:[:b | b bitTest:16r80]. |
|
1414 |
||
1415 |
" |
|
1416 |
#[1 2 3 1 2 3 1 2 127 ] asExternalBytes containsNon7BitAscii |
|
1417 |
#[1 2 3 1 2 3 1 2 250 251 250 251 255] asExternalBytes containsNon7BitAscii |
|
1418 |
" |
|
1419 |
! |
|
1420 |
||
9389 | 1421 |
isValid |
19495 | 1422 |
"true if I have an address" |
9389 | 1423 |
|
1424 |
%{ /* NOCONTEXT */ |
|
19495 | 1425 |
RETURN ((__INST(address_) == 0) ? false : true ); |
9389 | 1426 |
%} |
1427 |
! |
|
1428 |
||
6459 | 1429 |
species |
1430 |
"when copying, or concatenating, return instances of this class" |
|
1431 |
||
1432 |
^ ByteArray |
|
5557 | 1433 |
! ! |
1434 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1435 |
!ExternalBytes methodsFor:'registration'! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1436 |
|
8908 | 1437 |
protectFromGC |
6459 | 1438 |
"enter a reference to the receiver into the AllocatedInstances |
1439 |
class variable - this prevents it from ever being finalized by |
|
1440 |
the garbage collector, thus protecting the underlying memory." |
|
1441 |
||
10137
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1442 |
|wasBlocked| |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1443 |
|
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1444 |
|
11854 | 1445 |
"using a Semaphore can cause a deadlock, since unprotectFromGC may be called by |
10137
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1446 |
a finalization method" |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1447 |
|
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1448 |
wasBlocked := OperatingSystem blockInterrupts. |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1449 |
"/ AccessLock critical:[ |
11854 | 1450 |
AllocatedInstances isNil ifTrue:[ |
1451 |
AllocatedInstances := IdentitySet new |
|
1452 |
]. |
|
1453 |
AllocatedInstances add:self. |
|
10137
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1454 |
"/ ] |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1455 |
wasBlocked ifFalse:[OperatingSystem unblockInterrupts]. |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1456 |
! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1457 |
|
8908 | 1458 |
unprotectFromGC |
6459 | 1459 |
"remove the receiver from the AllocatedInstances |
1460 |
class variable - if there is no other reference to the receiver, |
|
15398 | 1461 |
and this was ever allocated by me (i.e. not by the outside world), |
6459 | 1462 |
the next garbage collect will finalize the receiver and the underlying |
1463 |
memory be freed." |
|
1464 |
||
10137
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1465 |
|wasBlocked| |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1466 |
|
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1467 |
"using a Semaphore can cause a deadlock, since protectFromGC may be interrupted by me |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1468 |
being called by a finalization method" |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1469 |
|
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1470 |
wasBlocked := OperatingSystem blockInterrupts. |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1471 |
"/ AccessLock critical:[ |
11854 | 1472 |
AllocatedInstances notNil ifTrue:[ |
18653 | 1473 |
AllocatedInstances remove:self ifAbsent:nil. |
10138 | 1474 |
]. |
10137
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1475 |
"/ ] |
7bfdc51fcb65
Avoid deadlock when free is called by finalization code (Stefan Vogel)
Michael Beyl <mb@exept.de>
parents:
9895
diff
changeset
|
1476 |
wasBlocked ifFalse:[OperatingSystem unblockInterrupts]. |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1477 |
! ! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1478 |
|
6457 | 1479 |
!ExternalBytes methodsFor:'resizing'! |
1480 |
||
1481 |
grow:numberOfBytes |
|
1482 |
"reallocate (realloc) numberOfBytes. |
|
1483 |
Raise MallocFailure if realloc fails to allocate enough memory" |
|
1484 |
||
1485 |
|mallocStatus| |
|
1486 |
||
16705 | 1487 |
size == numberOfBytes ifTrue:[^ self]. |
1488 |
||
6457 | 1489 |
%{ |
19376 | 1490 |
if (__isSmallInteger(numberOfBytes)) { |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1491 |
INT nBytes = __smallIntegerVal(numberOfBytes); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1492 |
if (nBytes > 0) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1493 |
char *space; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1494 |
char *prevSpace = (char *)__INST(address_); |
6457 | 1495 |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1496 |
if (prevSpace == (char *)nil) |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1497 |
prevSpace = 0; /* allocate from scratch */ |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1498 |
space = __stx_realloc(prevSpace, nBytes); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1499 |
if (space) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1500 |
__INST(address_) = (OBJ)space; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1501 |
__INST(size) = numberOfBytes; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1502 |
if (space == prevSpace) { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1503 |
/* same address, no re-registration */ |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1504 |
RETURN(self); |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1505 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1506 |
mallocStatus = true; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1507 |
} else { |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1508 |
mallocStatus = false; |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1509 |
} |
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1510 |
} |
6457 | 1511 |
} |
1512 |
%}. |
|
1513 |
mallocStatus == true ifTrue:[ |
|
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1514 |
Lobby registerChange:self. |
6457 | 1515 |
] ifFalse:[mallocStatus == false ifTrue:[ |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1516 |
^ MallocFailure raiseRequestWith:numberOfBytes. |
6457 | 1517 |
] ifFalse:[ |
19860
324edacff5cc
unified cpu and os defines;
Claus Gittinger <cg@exept.de>
parents:
19512
diff
changeset
|
1518 |
self primitiveFailed. |
6457 | 1519 |
]]. |
1520 |
! ! |
|
1521 |
||
14080 | 1522 |
!ExternalBytes methodsFor:'testing'! |
1523 |
||
1524 |
isExternalBytes |
|
1525 |
^ true |
|
1526 |
! ! |
|
1527 |
||
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1528 |
!ExternalBytes class methodsFor:'documentation'! |
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1529 |
|
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1530 |
version |
18580 | 1531 |
^ '$Header$' |
12594
d7267a747c2f
changed: #copyCStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
11854
diff
changeset
|
1532 |
! |
d7267a747c2f
changed: #copyCStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
11854
diff
changeset
|
1533 |
|
d7267a747c2f
changed: #copyCStringFromHeap
Claus Gittinger <cg@exept.de>
parents:
11854
diff
changeset
|
1534 |
version_CVS |
18580 | 1535 |
^ '$Header$' |
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1536 |
! ! |
7184 | 1537 |
|
14749 | 1538 |
|
848
76a83f34c26a
moved ExtBytes & ExtFunc from libbasic2
Claus Gittinger <cg@exept.de>
parents:
diff
changeset
|
1539 |
ExternalBytes initialize! |