if(sizeclass == 0) {
// Large object.
mstats.alloc -= s->npages<<PageShift;
- sys·memclr(v, s->npages<<PageShift);
+ sys_memclr(v, s->npages<<PageShift);
MHeap_Free(&mheap, s);
return;
}
// Small object.
c = m->mcache;
size = class_to_size[sizeclass];
- sys·memclr(v, size);
+ sys_memclr(v, size);
mstats.alloc -= size;
MCache_Free(c, v, sizeclass, size);
}
SysAlloc(uintptr n)
{
mstats.sys += n;
- return sys·mmap(nil, n, PROT_READ|PROT_WRITE, MAP_ANON|MAP_PRIVATE, 0, 0);
+ return sys_mmap(nil, n, PROT_READ|PROT_WRITE, MAP_ANON|MAP_PRIVATE, 0, 0);
}
void
if(0) {
byte *p;
- int32 i;
+ uint32 i;
p = v;
for(i=0; i<n; i++) {
if(p[i] != 0) {
// Go function stubs.
+#ifndef __GNUC__
+#define malloc_Alloc malloc·Alloc
+#define malloc_Free malloc·Free
+#define malloc_Lookup malloc·Lookup
+#define malloc_GetStats malloc·GetStats
+#endif
+
void
-malloc·Alloc(uintptr n, byte *p)
+malloc_Alloc(uintptr n, byte *p)
{
p = malloc(n);
FLUSH(&p);
}
void
-malloc·Free(byte *p)
+malloc_Free(byte *p)
{
free(p);
}
void
-malloc·Lookup(byte *p, byte *base, uintptr size)
+malloc_Lookup(byte *p, byte *base, uintptr size)
{
mlookup(p, &base, &size);
}
void
-malloc·GetStats(MStats *s)
+malloc_GetStats(MStats *s)
{
s = &mstats;
FLUSH(&s);
{
byte *v;
- v = sys·mmap(nil, n, PROT_READ|PROT_WRITE, MAP_ANON|MAP_PRIVATE, 0, 0);
+ v = sys_mmap(nil, n, PROT_READ|PROT_WRITE, MAP_ANON|MAP_PRIVATE, 0, 0);
m->mem.nmmap += n;
return v;
}
// hunk, and then once brk returned we'd immediately
// overwrite that hunk with our own.
// (the net result would be a memory leak, not a crash.)
- // so we have to call sys·mmap directly - it is written
+ // so we have to call sys_mmap directly - it is written
// in assembly and tagged not to grow the stack.
m->mem.hunk =
- sys·mmap(nil, NHUNK, PROT_READ|PROT_WRITE,
+ sys_mmap(nil, NHUNK, PROT_READ|PROT_WRITE,
MAP_ANON|MAP_PRIVATE, 0, 0);
m->mem.nhunk = NHUNK;
m->mem.nmmap += NHUNK;
}
void
-sys·mal(uint32 n, uint8 *ret)
+sys_mal(uint32 n, uint8 *ret)
{
ret = mal(n);
FLUSH(&ret);
void notesleep(Note*);
void notewakeup(Note*);
+/*
+ * Redefine methods for the benefit of gcc, which does not support
+ * UTF-8 characters in identifiers.
+ */
+#ifndef __GNUC__
+#define sys_exit sys·exit
+#define sys_gosched sys·gosched
+#define sys_memclr sys·memclr
+#define sys_write sys·write
+#define sys_breakpoint sys·breakpoint
+#define sys_bytestorune sys·bytestorune
+#define sys_catstring sys·catstring
+#define sys_cmpstring sys·cmpstring
+#define sys_getcallerpc sys·getcallerpc
+#define sys_goexit sys·goexit
+#define sys_indexstring sys·indexstring
+#define sys_intstring sys·intstring
+#define sys_mal sys·mal
+#define sys_mmap sys·mmap
+#define sys_printarray sys·printarray
+#define sys_printbool sys·printbool
+#define sys_printfloat sys·printfloat
+#define sys_printhex sys·printhex
+#define sys_printint sys·printint
+#define sys_printpc sys·printpc
+#define sys_printpointer sys·printpointer
+#define sys_printstring sys·printstring
+#define sys_printuint sys·printuint
+#define sys_readfile sys·readfile
+#define sys_semacquire sys·semacquire
+#define sys_semrelease sys·semrelease
+#define sys_setcallerpc sys·setcallerpc
+#define sys_slicestring sys·slicestring
+#define sys_stringtorune sys·stringtorune
+#endif
+
/*
* low level go -called
*/
-void sys·goexit(void);
-void sys·gosched(void);
-void sys·exit(int32);
-void sys·write(int32, void*, int32);
-void sys·breakpoint(void);
-uint8* sys·mmap(byte*, uint32, int32, int32, int32, uint32);
-void sys·memclr(byte*, uint32);
-void sys·setcallerpc(void*, void*);
-void* sys·getcallerpc(void*);
+void sys_goexit(void);
+void sys_gosched(void);
+void sys_exit(int32);
+void sys_write(int32, void*, int32);
+void sys_breakpoint(void);
+uint8* sys_mmap(byte*, uint32, int32, int32, int32, uint32);
+void sys_memclr(byte*, uint32);
+void sys_setcallerpc(void*, void*);
+void* sys_getcallerpc(void*);
/*
* runtime go-called
*/
-void sys·printbool(bool);
-void sys·printfloat(float64);
-void sys·printint(int64);
-void sys·printstring(string);
-void sys·printpc(void*);
-void sys·printpointer(void*);
-void sys·printuint(uint64);
-void sys·printhex(uint64);
-void sys·printarray(Array);
-void sys·catstring(string, string, string);
-void sys·cmpstring(string, string, int32);
-void sys·slicestring(string, int32, int32, string);
-void sys·indexstring(string, int32, byte);
-void sys·intstring(int64, string);
+void sys_printbool(bool);
+void sys_printfloat(float64);
+void sys_printint(int64);
+void sys_printstring(string);
+void sys_printpc(void*);
+void sys_printpointer(void*);
+void sys_printuint(uint64);
+void sys_printhex(uint64);
+void sys_printarray(Array);
+void sys_catstring(string, string, string);
+void sys_cmpstring(string, string, int32);
+void sys_slicestring(string, int32, int32, string);
+void sys_indexstring(string, int32, byte);
+void sys_intstring(int64, string);
bool isInf(float64, int32);
bool isNaN(float64);
/*
* User go-called
*/
-void sys·readfile(string, string, bool);
-void sys·bytestorune(byte*, int32, int32, int32, int32);
-void sys·stringtorune(string, int32, int32, int32);
-void sys·semacquire(uint32*);
-void sys·semrelease(uint32*);
+void sys_readfile(string, string, bool);
+void sys_bytestorune(byte*, int32, int32, int32, int32);
+void sys_stringtorune(string, int32, int32, int32);
+void sys_semacquire(uint32*);
+void sys_semrelease(uint32*);