libc_darwin.go 70 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789
  1. // Copyright 2020 The Libc Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. package libc // import "modernc.org/libc"
  5. import (
  6. crand "crypto/rand"
  7. "encoding/hex"
  8. "errors"
  9. "fmt"
  10. "io"
  11. "io/fs"
  12. mbits "math/bits"
  13. "os"
  14. "os/exec"
  15. gosignal "os/signal"
  16. "path/filepath"
  17. "runtime"
  18. "strings"
  19. gotime "time"
  20. "unicode"
  21. "unsafe"
  22. guuid "github.com/google/uuid"
  23. "golang.org/x/sys/unix"
  24. "modernc.org/libc/errno"
  25. "modernc.org/libc/fcntl"
  26. "modernc.org/libc/fts"
  27. gonetdb "modernc.org/libc/honnef.co/go/netdb"
  28. "modernc.org/libc/langinfo"
  29. "modernc.org/libc/limits"
  30. "modernc.org/libc/netdb"
  31. "modernc.org/libc/netinet/in"
  32. "modernc.org/libc/signal"
  33. "modernc.org/libc/stdio"
  34. "modernc.org/libc/sys/socket"
  35. "modernc.org/libc/sys/stat"
  36. "modernc.org/libc/sys/types"
  37. "modernc.org/libc/termios"
  38. "modernc.org/libc/time"
  39. "modernc.org/libc/unistd"
  40. "modernc.org/libc/uuid/uuid"
  41. "modernc.org/libc/wctype"
  42. "modernc.org/memory"
  43. )
  44. const (
  45. maxPathLen = 1024
  46. )
  47. // var (
  48. // in6_addr_any in.In6_addr
  49. // )
  50. type Tsize_t = types.Size_t
  51. type (
  52. syscallErrno = unix.Errno
  53. long = types.User_long_t
  54. ulong = types.User_ulong_t
  55. )
  56. // // Keep these outside of the var block otherwise go generate will miss them.
  57. var X__stderrp = Xstdout
  58. var X__stdinp = Xstdin
  59. var X__stdoutp = Xstdout
  60. // user@darwin-m1:~/tmp$ cat main.c
  61. //
  62. // #include <xlocale.h>
  63. // #include <stdio.h>
  64. //
  65. // int main() {
  66. // printf("%i\n", ___mb_cur_max());
  67. // return 0;
  68. // }
  69. //
  70. // user@darwin-m1:~/tmp$ gcc main.c && ./a.out
  71. // 1
  72. // user@darwin-m1:~/tmp$
  73. var X__mb_cur_max int32 = 1
  74. var startTime = gotime.Now() // For clock(3)
  75. type file uintptr
  76. func (f file) fd() int32 { return int32((*stdio.FILE)(unsafe.Pointer(f)).F_file) }
  77. func (f file) setFd(fd int32) { (*stdio.FILE)(unsafe.Pointer(f)).F_file = int16(fd) }
  78. func (f file) err() bool {
  79. return (*stdio.FILE)(unsafe.Pointer(f)).F_flags&1 != 0
  80. }
  81. func (f file) setErr() {
  82. (*stdio.FILE)(unsafe.Pointer(f)).F_flags |= 1
  83. }
  84. func (f file) clearErr() {
  85. (*stdio.FILE)(unsafe.Pointer(f)).F_flags &^= 3
  86. }
  87. func (f file) eof() bool {
  88. return (*stdio.FILE)(unsafe.Pointer(f)).F_flags&2 != 0
  89. }
  90. func (f file) setEOF() {
  91. (*stdio.FILE)(unsafe.Pointer(f)).F_flags |= 2
  92. }
  93. func (f file) close(t *TLS) int32 {
  94. r := Xclose(t, f.fd())
  95. Xfree(t, uintptr(f))
  96. if r < 0 {
  97. return stdio.EOF
  98. }
  99. return 0
  100. }
  101. func newFile(t *TLS, fd int32) uintptr {
  102. p := Xcalloc(t, 1, types.Size_t(unsafe.Sizeof(stdio.FILE{})))
  103. if p == 0 {
  104. return 0
  105. }
  106. file(p).setFd(fd)
  107. return p
  108. }
  109. func fwrite(fd int32, b []byte) (int, error) {
  110. if fd == unistd.STDOUT_FILENO {
  111. return write(b)
  112. }
  113. if dmesgs {
  114. dmesg("%v: fd %v: %s", origin(1), fd, hex.Dump(b))
  115. }
  116. return unix.Write(int(fd), b)
  117. }
  118. func Xclearerr(tls *TLS, f uintptr) {
  119. file(f).clearErr()
  120. }
  121. func Xfeof(t *TLS, f uintptr) (r int32) {
  122. if __ccgo_strace {
  123. trc("t=%v f=%v, (%v:)", t, f, origin(2))
  124. defer func() { trc("-> %v", r) }()
  125. }
  126. r = BoolInt32(file(f).eof())
  127. return r
  128. }
  129. func X__inline_isnand(t *TLS, x float64) int32 {
  130. if __ccgo_strace {
  131. trc("t=%v x=%v, (%v:)", t, x, origin(2))
  132. }
  133. return Xisnan(t, x)
  134. }
  135. func X__inline_isnanf(t *TLS, x float32) int32 {
  136. if __ccgo_strace {
  137. trc("t=%v x=%v, (%v:)", t, x, origin(2))
  138. }
  139. return Xisnanf(t, x)
  140. }
  141. func X__inline_isnanl(t *TLS, x float64) int32 {
  142. if __ccgo_strace {
  143. trc("t=%v x=%v, (%v:)", t, x, origin(2))
  144. }
  145. return Xisnan(t, x)
  146. }
  147. // int fprintf(FILE *stream, const char *format, ...);
  148. func Xfprintf(t *TLS, stream, format, args uintptr) int32 {
  149. if __ccgo_strace {
  150. trc("t=%v args=%v, (%v:)", t, args, origin(2))
  151. }
  152. n, _ := fwrite(int32((*stdio.FILE)(unsafe.Pointer(stream)).F_file), printf(format, args))
  153. return int32(n)
  154. }
  155. // int usleep(useconds_t usec);
  156. func Xusleep(t *TLS, usec types.Useconds_t) int32 {
  157. if __ccgo_strace {
  158. trc("t=%v usec=%v, (%v:)", t, usec, origin(2))
  159. }
  160. gotime.Sleep(gotime.Microsecond * gotime.Duration(usec))
  161. return 0
  162. }
  163. // int futimes(int fd, const struct timeval tv[2]);
  164. func Xfutimes(t *TLS, fd int32, tv uintptr) int32 {
  165. if __ccgo_strace {
  166. trc("t=%v fd=%v tv=%v, (%v:)", t, fd, tv, origin(2))
  167. }
  168. var a []unix.Timeval
  169. if tv != 0 {
  170. a = make([]unix.Timeval, 2)
  171. a[0] = *(*unix.Timeval)(unsafe.Pointer(tv))
  172. a[1] = *(*unix.Timeval)(unsafe.Pointer(tv + unsafe.Sizeof(unix.Timeval{})))
  173. }
  174. if err := unix.Futimes(int(fd), a); err != nil {
  175. if dmesgs {
  176. dmesg("%v: %v FAIL", origin(1), err)
  177. }
  178. t.setErrno(err)
  179. return -1
  180. }
  181. if dmesgs {
  182. dmesg("%v: ok", origin(1))
  183. }
  184. return 0
  185. }
  186. // void srandomdev(void);
  187. func Xsrandomdev(t *TLS) {
  188. if __ccgo_strace {
  189. trc("t=%v, (%v:)", t, origin(2))
  190. }
  191. panic(todo(""))
  192. }
  193. // int gethostuuid(uuid_t id, const struct timespec *wait);
  194. func Xgethostuuid(t *TLS, id uintptr, wait uintptr) int32 {
  195. if __ccgo_strace {
  196. trc("t=%v id=%v wait=%v, (%v:)", t, id, wait, origin(2))
  197. }
  198. if _, _, err := unix.Syscall(unix.SYS_GETHOSTUUID, id, wait, 0); err != 0 { // Cannot avoid the syscall here.
  199. if dmesgs {
  200. dmesg("%v: %v FAIL", origin(1), err)
  201. }
  202. t.setErrno(err)
  203. return -1
  204. }
  205. if dmesgs {
  206. dmesg("%v: ok", origin(1))
  207. }
  208. return 0
  209. }
  210. // int flock(int fd, int operation);
  211. func Xflock(t *TLS, fd, operation int32) int32 {
  212. if __ccgo_strace {
  213. trc("t=%v operation=%v, (%v:)", t, operation, origin(2))
  214. }
  215. if err := unix.Flock(int(fd), int(operation)); err != nil {
  216. if dmesgs {
  217. dmesg("%v: %v FAIL", origin(1), err)
  218. }
  219. t.setErrno(err)
  220. return -1
  221. }
  222. if dmesgs {
  223. dmesg("%v: ok", origin(1))
  224. }
  225. return 0
  226. }
  227. // int fsctl(const char *,unsigned long,void*,unsigned int);
  228. func Xfsctl(t *TLS, path uintptr, request ulong, data uintptr, options uint32) int32 {
  229. if __ccgo_strace {
  230. trc("t=%v path=%v request=%v data=%v options=%v, (%v:)", t, path, request, data, options, origin(2))
  231. }
  232. panic(todo(""))
  233. // if _, _, err := unix.Syscall6(unix.SYS_FSCTL, path, uintptr(request), data, uintptr(options), 0, 0); err != 0 {
  234. // t.setErrno(err)
  235. // return -1
  236. // }
  237. // return 0
  238. }
  239. // int * __error(void);
  240. func X__error(t *TLS) uintptr {
  241. if __ccgo_strace {
  242. trc("t=%v, (%v:)", t, origin(2))
  243. }
  244. return t.errnop
  245. }
  246. // int isspace(int c);
  247. func Xisspace(t *TLS, c int32) int32 {
  248. if __ccgo_strace {
  249. trc("t=%v c=%v, (%v:)", t, c, origin(2))
  250. }
  251. return __isspace(t, c)
  252. }
  253. // void __assert_rtn(const char *, const char *, int, const char *)
  254. func X__assert_rtn(t *TLS, function, file uintptr, line int32, assertion uintptr) {
  255. if __ccgo_strace {
  256. trc("t=%v file=%v line=%v assertion=%v, (%v:)", t, file, line, assertion, origin(2))
  257. }
  258. panic(todo(""))
  259. // fmt.Fprintf(os.Stderr, "assertion failure: %s:%d.%s: %s\n", GoString(file), line, GoString(function), GoString(assertion))
  260. // os.Stderr.Sync()
  261. // Xexit(t, 1)
  262. }
  263. // int getrusage(int who, struct rusage *usage);
  264. func Xgetrusage(t *TLS, who int32, usage uintptr) int32 {
  265. if __ccgo_strace {
  266. trc("t=%v who=%v usage=%v, (%v:)", t, who, usage, origin(2))
  267. }
  268. panic(todo(""))
  269. // if _, _, err := unix.Syscall(unix.SYS_GETRUSAGE, uintptr(who), usage, 0); err != 0 {
  270. // t.setErrno(err)
  271. // return -1
  272. // }
  273. // return 0
  274. }
  275. // int fgetc(FILE *stream);
  276. func Xfgetc(t *TLS, stream uintptr) int32 {
  277. if __ccgo_strace {
  278. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  279. }
  280. fd := int((*stdio.FILE)(unsafe.Pointer(stream)).F_file)
  281. var buf [1]byte
  282. if n, _ := unix.Read(fd, buf[:]); n != 0 {
  283. return int32(buf[0])
  284. }
  285. return stdio.EOF
  286. }
  287. // int lstat(const char *pathname, struct stat *statbuf);
  288. func Xlstat(t *TLS, pathname, statbuf uintptr) int32 {
  289. if __ccgo_strace {
  290. trc("t=%v statbuf=%v, (%v:)", t, statbuf, origin(2))
  291. }
  292. return Xlstat64(t, pathname, statbuf)
  293. }
  294. // int stat(const char *pathname, struct stat *statbuf);
  295. func Xstat(t *TLS, pathname, statbuf uintptr) int32 {
  296. if __ccgo_strace {
  297. trc("t=%v statbuf=%v, (%v:)", t, statbuf, origin(2))
  298. }
  299. return Xstat64(t, pathname, statbuf)
  300. }
  301. // int chdir(const char *path);
  302. func Xchdir(t *TLS, path uintptr) int32 {
  303. if __ccgo_strace {
  304. trc("t=%v path=%v, (%v:)", t, path, origin(2))
  305. }
  306. if err := unix.Chdir(GoString(path)); err != nil {
  307. if dmesgs {
  308. dmesg("%v: %q: %v FAIL", origin(1), GoString(path), err)
  309. }
  310. t.setErrno(err)
  311. return -1
  312. }
  313. if dmesgs {
  314. dmesg("%v: %q: ok", origin(1), GoString(path))
  315. }
  316. return 0
  317. }
  318. var localtime time.Tm
  319. // struct tm *localtime(const time_t *timep);
  320. func Xlocaltime(_ *TLS, timep uintptr) uintptr {
  321. loc := getLocalLocation()
  322. ut := *(*time.Time_t)(unsafe.Pointer(timep))
  323. t := gotime.Unix(int64(ut), 0).In(loc)
  324. localtime.Ftm_sec = int32(t.Second())
  325. localtime.Ftm_min = int32(t.Minute())
  326. localtime.Ftm_hour = int32(t.Hour())
  327. localtime.Ftm_mday = int32(t.Day())
  328. localtime.Ftm_mon = int32(t.Month() - 1)
  329. localtime.Ftm_year = int32(t.Year() - 1900)
  330. localtime.Ftm_wday = int32(t.Weekday())
  331. localtime.Ftm_yday = int32(t.YearDay())
  332. localtime.Ftm_isdst = Bool32(isTimeDST(t))
  333. _, off := t.Zone()
  334. localtime.Ftm_gmtoff = int64(off)
  335. localtime.Ftm_zone = 0
  336. return uintptr(unsafe.Pointer(&localtime))
  337. }
  338. // struct tm *localtime_r(const time_t *timep, struct tm *result);
  339. func Xlocaltime_r(_ *TLS, timep, result uintptr) uintptr {
  340. loc := getLocalLocation()
  341. ut := *(*time_t)(unsafe.Pointer(timep))
  342. t := gotime.Unix(int64(ut), 0).In(loc)
  343. (*time.Tm)(unsafe.Pointer(result)).Ftm_sec = int32(t.Second())
  344. (*time.Tm)(unsafe.Pointer(result)).Ftm_min = int32(t.Minute())
  345. (*time.Tm)(unsafe.Pointer(result)).Ftm_hour = int32(t.Hour())
  346. (*time.Tm)(unsafe.Pointer(result)).Ftm_mday = int32(t.Day())
  347. (*time.Tm)(unsafe.Pointer(result)).Ftm_mon = int32(t.Month() - 1)
  348. (*time.Tm)(unsafe.Pointer(result)).Ftm_year = int32(t.Year() - 1900)
  349. (*time.Tm)(unsafe.Pointer(result)).Ftm_wday = int32(t.Weekday())
  350. (*time.Tm)(unsafe.Pointer(result)).Ftm_yday = int32(t.YearDay())
  351. (*time.Tm)(unsafe.Pointer(result)).Ftm_isdst = Bool32(isTimeDST(t))
  352. _, off := t.Zone()
  353. (*time.Tm)(unsafe.Pointer(result)).Ftm_gmtoff = int64(off)
  354. (*time.Tm)(unsafe.Pointer(result)).Ftm_zone = 0
  355. return result
  356. }
  357. // int open(const char *pathname, int flags, ...);
  358. func Xopen(t *TLS, pathname uintptr, flags int32, args uintptr) int32 {
  359. if __ccgo_strace {
  360. trc("t=%v pathname=%v flags=%v args=%v, (%v:)", t, pathname, flags, args, origin(2))
  361. }
  362. var mode types.Mode_t
  363. if args != 0 {
  364. mode = (types.Mode_t)(VaUint32(&args))
  365. }
  366. fd, err := unix.Open(GoString(pathname), int(flags), uint32(mode))
  367. if err != nil {
  368. if dmesgs {
  369. dmesg("%v: %q %#x %#o: %v FAIL", origin(1), GoString(pathname), flags, mode, err)
  370. }
  371. t.setErrno(err)
  372. return -1
  373. }
  374. if dmesgs {
  375. dmesg("%v: %q flags %#x mode %#o: fd %v", origin(1), GoString(pathname), flags, mode, fd)
  376. }
  377. return int32(fd)
  378. }
  379. // off_t lseek(int fd, off_t offset, int whence);
  380. func Xlseek(t *TLS, fd int32, offset types.Off_t, whence int32) types.Off_t {
  381. if __ccgo_strace {
  382. trc("t=%v fd=%v offset=%v whence=%v, (%v:)", t, fd, offset, whence, origin(2))
  383. }
  384. return types.Off_t(Xlseek64(t, fd, offset, whence))
  385. }
  386. func whenceStr(whence int32) string {
  387. switch whence {
  388. case fcntl.SEEK_CUR:
  389. return "SEEK_CUR"
  390. case fcntl.SEEK_END:
  391. return "SEEK_END"
  392. case fcntl.SEEK_SET:
  393. return "SEEK_SET"
  394. default:
  395. return fmt.Sprintf("whence(%d)", whence)
  396. }
  397. }
  398. var fsyncStatbuf stat.Stat
  399. // int fsync(int fd);
  400. func Xfsync(t *TLS, fd int32) int32 {
  401. if __ccgo_strace {
  402. trc("t=%v fd=%v, (%v:)", t, fd, origin(2))
  403. }
  404. if noFsync {
  405. // Simulate -DSQLITE_NO_SYNC for sqlite3 testfixture, see function full_sync in sqlite3.c
  406. return Xfstat(t, fd, uintptr(unsafe.Pointer(&fsyncStatbuf)))
  407. }
  408. if err := unix.Fsync(int(fd)); err != nil {
  409. if dmesgs {
  410. dmesg("%v: %v: %v FAIL", origin(1), fd, err)
  411. }
  412. t.setErrno(err)
  413. return -1
  414. }
  415. if dmesgs {
  416. dmesg("%v: %d: ok", origin(1), fd)
  417. }
  418. return 0
  419. }
  420. // long sysconf(int name);
  421. func Xsysconf(t *TLS, name int32) long {
  422. if __ccgo_strace {
  423. trc("t=%v name=%v, (%v:)", t, name, origin(2))
  424. }
  425. switch name {
  426. case unistd.X_SC_PAGESIZE:
  427. return long(unix.Getpagesize())
  428. case unistd.X_SC_NPROCESSORS_ONLN:
  429. return long(runtime.NumCPU())
  430. case unistd.X_SC_GETPW_R_SIZE_MAX:
  431. return 128
  432. }
  433. panic(todo("", name))
  434. }
  435. // int close(int fd);
  436. func Xclose(t *TLS, fd int32) int32 {
  437. if __ccgo_strace {
  438. trc("t=%v fd=%v, (%v:)", t, fd, origin(2))
  439. }
  440. if err := unix.Close(int(fd)); err != nil {
  441. if dmesgs {
  442. dmesg("%v: %v FAIL", origin(1), err)
  443. }
  444. t.setErrno(err)
  445. return -1
  446. }
  447. if dmesgs {
  448. dmesg("%v: %d: ok", origin(1), fd)
  449. }
  450. return 0
  451. }
  452. // char *getcwd(char *buf, size_t size);
  453. func Xgetcwd(t *TLS, buf uintptr, size types.Size_t) uintptr {
  454. if __ccgo_strace {
  455. trc("t=%v buf=%v size=%v, (%v:)", t, buf, size, origin(2))
  456. }
  457. if _, err := unix.Getcwd((*RawMem)(unsafe.Pointer(buf))[:size:size]); err != nil {
  458. if dmesgs {
  459. dmesg("%v: %v FAIL", origin(1), err)
  460. }
  461. t.setErrno(err)
  462. return 0
  463. }
  464. if dmesgs {
  465. dmesg("%v: ok", origin(1))
  466. }
  467. return buf
  468. }
  469. // int fstat(int fd, struct stat *statbuf);
  470. func Xfstat(t *TLS, fd int32, statbuf uintptr) int32 {
  471. if __ccgo_strace {
  472. trc("t=%v fd=%v statbuf=%v, (%v:)", t, fd, statbuf, origin(2))
  473. }
  474. return Xfstat64(t, fd, statbuf)
  475. }
  476. // int ftruncate(int fd, off_t length);
  477. func Xftruncate(t *TLS, fd int32, length types.Off_t) int32 {
  478. if __ccgo_strace {
  479. trc("t=%v fd=%v length=%v, (%v:)", t, fd, length, origin(2))
  480. }
  481. if err := unix.Ftruncate(int(fd), int64(length)); err != nil {
  482. if dmesgs {
  483. dmesg("%v: fd %d: %v FAIL", origin(1), fd, err)
  484. }
  485. t.setErrno(err)
  486. return -1
  487. }
  488. if dmesgs {
  489. dmesg("%v: %d %#x: ok", origin(1), fd, length)
  490. }
  491. return 0
  492. }
  493. // int fcntl(int fd, int cmd, ... /* arg */ );
  494. func Xfcntl(t *TLS, fd, cmd int32, args uintptr) int32 {
  495. if __ccgo_strace {
  496. trc("t=%v cmd=%v args=%v, (%v:)", t, cmd, args, origin(2))
  497. }
  498. return Xfcntl64(t, fd, cmd, args)
  499. }
  500. // ssize_t read(int fd, void *buf, size_t count);
  501. func Xread(t *TLS, fd int32, buf uintptr, count types.Size_t) types.Ssize_t {
  502. if __ccgo_strace {
  503. trc("t=%v fd=%v buf=%v count=%v, (%v:)", t, fd, buf, count, origin(2))
  504. }
  505. var n int
  506. var err error
  507. switch {
  508. case count == 0:
  509. n, err = unix.Read(int(fd), nil)
  510. default:
  511. n, err = unix.Read(int(fd), (*RawMem)(unsafe.Pointer(buf))[:count:count])
  512. if dmesgs && err == nil {
  513. dmesg("%v: fd %v, count %#x, n %#x\n%s", origin(1), fd, count, n, hex.Dump((*RawMem)(unsafe.Pointer(buf))[:n:n]))
  514. }
  515. }
  516. if err != nil {
  517. if dmesgs {
  518. dmesg("%v: fd %v, %v FAIL", origin(1), fd, err)
  519. }
  520. t.setErrno(err)
  521. return -1
  522. }
  523. if dmesgs {
  524. dmesg("%v: ok", origin(1))
  525. }
  526. return types.Ssize_t(n)
  527. }
  528. // ssize_t write(int fd, const void *buf, size_t count);
  529. func Xwrite(t *TLS, fd int32, buf uintptr, count types.Size_t) types.Ssize_t {
  530. if __ccgo_strace {
  531. trc("t=%v fd=%v buf=%v count=%v, (%v:)", t, fd, buf, count, origin(2))
  532. }
  533. var n int
  534. var err error
  535. switch {
  536. case count == 0:
  537. n, err = unix.Write(int(fd), nil)
  538. default:
  539. n, err = unix.Write(int(fd), (*RawMem)(unsafe.Pointer(buf))[:count:count])
  540. if dmesgs {
  541. dmesg("%v: fd %v, count %#x\n%s", origin(1), fd, count, hex.Dump((*RawMem)(unsafe.Pointer(buf))[:count:count]))
  542. }
  543. }
  544. if err != nil {
  545. if dmesgs {
  546. dmesg("%v: %v FAIL", origin(1), err)
  547. }
  548. t.setErrno(err)
  549. return -1
  550. }
  551. if dmesgs {
  552. dmesg("%v: ok", origin(1))
  553. }
  554. return types.Ssize_t(n)
  555. }
  556. // int fchmod(int fd, mode_t mode);
  557. func Xfchmod(t *TLS, fd int32, mode types.Mode_t) int32 {
  558. if __ccgo_strace {
  559. trc("t=%v fd=%v mode=%v, (%v:)", t, fd, mode, origin(2))
  560. }
  561. if err := unix.Fchmod(int(fd), uint32(mode)); err != nil {
  562. if dmesgs {
  563. dmesg("%v: %d %#o: %v FAIL", origin(1), fd, mode, err)
  564. }
  565. t.setErrno(err)
  566. return -1
  567. }
  568. if dmesgs {
  569. dmesg("%v: %d %#o: ok", origin(1), fd, mode)
  570. }
  571. return 0
  572. }
  573. // int fchown(int fd, uid_t owner, gid_t group);
  574. func Xfchown(t *TLS, fd int32, owner types.Uid_t, group types.Gid_t) int32 {
  575. if __ccgo_strace {
  576. trc("t=%v fd=%v owner=%v group=%v, (%v:)", t, fd, owner, group, origin(2))
  577. }
  578. if _, _, err := unix.Syscall(unix.SYS_FCHOWN, uintptr(fd), uintptr(owner), uintptr(group)); err != 0 {
  579. t.setErrno(err)
  580. return -1
  581. }
  582. return 0
  583. }
  584. // uid_t geteuid(void);
  585. func Xgeteuid(t *TLS) types.Uid_t {
  586. if __ccgo_strace {
  587. trc("t=%v, (%v:)", t, origin(2))
  588. }
  589. r := types.Uid_t(unix.Geteuid())
  590. if dmesgs {
  591. dmesg("%v: %v", origin(1), r)
  592. }
  593. return r
  594. }
  595. // void *mmap(void *addr, size_t length, int prot, int flags, int fd, off_t offset);
  596. func Xmmap(t *TLS, addr uintptr, length types.Size_t, prot, flags, fd int32, offset types.Off_t) uintptr {
  597. if __ccgo_strace {
  598. trc("t=%v addr=%v length=%v fd=%v offset=%v, (%v:)", t, addr, length, fd, offset, origin(2))
  599. }
  600. // Cannot avoid the syscall here, addr sometimes matter.
  601. data, _, err := unix.Syscall6(unix.SYS_MMAP, addr, uintptr(length), uintptr(prot), uintptr(flags), uintptr(fd), uintptr(offset))
  602. if err != 0 {
  603. if dmesgs {
  604. dmesg("%v: %v FAIL", origin(1), err)
  605. }
  606. t.setErrno(err)
  607. return ^uintptr(0) // (void*)-1
  608. }
  609. if dmesgs {
  610. dmesg("%v: %#x", origin(1), data)
  611. }
  612. return data
  613. }
  614. // int munmap(void *addr, size_t length);
  615. func Xmunmap(t *TLS, addr uintptr, length types.Size_t) int32 {
  616. if __ccgo_strace {
  617. trc("t=%v addr=%v length=%v, (%v:)", t, addr, length, origin(2))
  618. }
  619. if _, _, err := unix.Syscall(unix.SYS_MUNMAP, addr, uintptr(length), 0); err != 0 { // Cannot avoid the syscall here, must pair with mmap.
  620. if dmesgs {
  621. dmesg("%v: %v FAIL", origin(1), err)
  622. }
  623. t.setErrno(err)
  624. return -1
  625. }
  626. return 0
  627. }
  628. // int gettimeofday(struct timeval *tv, struct timezone *tz);
  629. func Xgettimeofday(t *TLS, tv, tz uintptr) int32 {
  630. if __ccgo_strace {
  631. trc("t=%v tz=%v, (%v:)", t, tz, origin(2))
  632. }
  633. if tz != 0 {
  634. panic(todo(""))
  635. }
  636. var tvs unix.Timeval
  637. err := unix.Gettimeofday(&tvs)
  638. if err != nil {
  639. if dmesgs {
  640. dmesg("%v: %v FAIL", origin(1), err)
  641. }
  642. t.setErrno(err)
  643. return -1
  644. }
  645. *(*unix.Timeval)(unsafe.Pointer(tv)) = tvs
  646. return 0
  647. }
  648. // int getsockopt(int sockfd, int level, int optname, void *optval, socklen_t *optlen);
  649. func Xgetsockopt(t *TLS, sockfd, level, optname int32, optval, optlen uintptr) int32 {
  650. if __ccgo_strace {
  651. trc("t=%v optname=%v optlen=%v, (%v:)", t, optname, optlen, origin(2))
  652. }
  653. if _, _, err := unix.Syscall6(unix.SYS_GETSOCKOPT, uintptr(sockfd), uintptr(level), uintptr(optname), optval, optlen, 0); err != 0 {
  654. t.setErrno(err)
  655. return -1
  656. }
  657. return 0
  658. }
  659. // int setsockopt(int sockfd, int level, int optname, const void *optval, socklen_t optlen);
  660. func Xsetsockopt(t *TLS, sockfd, level, optname int32, optval uintptr, optlen socket.Socklen_t) int32 {
  661. if __ccgo_strace {
  662. trc("t=%v optname=%v optval=%v optlen=%v, (%v:)", t, optname, optval, optlen, origin(2))
  663. }
  664. if _, _, err := unix.Syscall6(unix.SYS_SETSOCKOPT, uintptr(sockfd), uintptr(level), uintptr(optname), optval, uintptr(optlen), 0); err != 0 {
  665. t.setErrno(err)
  666. return -1
  667. }
  668. return 0
  669. }
  670. // int ioctl(int fd, unsigned long request, ...);
  671. func Xioctl(t *TLS, fd int32, request ulong, va uintptr) int32 {
  672. if __ccgo_strace {
  673. trc("t=%v fd=%v request=%v va=%v, (%v:)", t, fd, request, va, origin(2))
  674. }
  675. var argp uintptr
  676. if va != 0 {
  677. argp = VaUintptr(&va)
  678. }
  679. n, _, err := unix.Syscall(unix.SYS_IOCTL, uintptr(fd), uintptr(request), argp)
  680. if err != 0 {
  681. t.setErrno(err)
  682. return -1
  683. }
  684. return int32(n)
  685. }
  686. // int getsockname(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
  687. func Xgetsockname(t *TLS, sockfd int32, addr, addrlen uintptr) int32 {
  688. if __ccgo_strace {
  689. trc("t=%v sockfd=%v addrlen=%v, (%v:)", t, sockfd, addrlen, origin(2))
  690. }
  691. if _, _, err := unix.Syscall(unix.SYS_GETSOCKNAME, uintptr(sockfd), addr, addrlen); err != 0 { // Cannot avoid the syscall here.
  692. if dmesgs {
  693. dmesg("%v: fd %v: %v FAIL", origin(1), sockfd, err)
  694. }
  695. t.setErrno(err)
  696. return -1
  697. }
  698. if dmesgs {
  699. dmesg("%v: fd %v: ok", origin(1), sockfd)
  700. }
  701. return 0
  702. }
  703. // int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout);
  704. func Xselect(t *TLS, nfds int32, readfds, writefds, exceptfds, timeout uintptr) int32 {
  705. if __ccgo_strace {
  706. trc("t=%v nfds=%v timeout=%v, (%v:)", t, nfds, timeout, origin(2))
  707. }
  708. n, err := unix.Select(
  709. int(nfds),
  710. (*unix.FdSet)(unsafe.Pointer(readfds)),
  711. (*unix.FdSet)(unsafe.Pointer(writefds)),
  712. (*unix.FdSet)(unsafe.Pointer(exceptfds)),
  713. (*unix.Timeval)(unsafe.Pointer(timeout)),
  714. )
  715. if err != nil {
  716. if dmesgs {
  717. dmesg("%v: %v FAIL", origin(1), err)
  718. }
  719. t.setErrno(err)
  720. return -1
  721. }
  722. if dmesgs {
  723. dmesg("%v: ok", origin(1))
  724. }
  725. return int32(n)
  726. }
  727. // int mkfifo(const char *pathname, mode_t mode);
  728. func Xmkfifo(t *TLS, pathname uintptr, mode types.Mode_t) int32 {
  729. if __ccgo_strace {
  730. trc("t=%v pathname=%v mode=%v, (%v:)", t, pathname, mode, origin(2))
  731. }
  732. if err := unix.Mkfifo(GoString(pathname), uint32(mode)); err != nil {
  733. t.setErrno(err)
  734. return -1
  735. }
  736. return 0
  737. }
  738. // mode_t umask(mode_t mask);
  739. func Xumask(t *TLS, mask types.Mode_t) types.Mode_t {
  740. if __ccgo_strace {
  741. trc("t=%v mask=%v, (%v:)", t, mask, origin(2))
  742. }
  743. return types.Mode_t(unix.Umask(int(mask)))
  744. }
  745. // // int execvp(const char *file, char *const argv[]);
  746. // func Xexecvp(t *TLS, file, argv uintptr) int32 {
  747. // if _, _, err := unix.Syscall(unix.SYS_EXECVE, file, argv, Environ()); err != 0 {
  748. // t.setErrno(err)
  749. // return -1
  750. // }
  751. //
  752. // return 0
  753. // }
  754. // pid_t (pid_t pid, int *wstatus, int options);
  755. func Xwaitpid(t *TLS, pid types.Pid_t, wstatus uintptr, optname int32) types.Pid_t {
  756. if __ccgo_strace {
  757. trc("t=%v pid=%v wstatus=%v optname=%v, (%v:)", t, pid, wstatus, optname, origin(2))
  758. }
  759. n, err := unix.Wait4(int(pid), (*unix.WaitStatus)(unsafe.Pointer(wstatus)), int(optname), nil)
  760. if err != nil {
  761. if dmesgs {
  762. dmesg("%v: %v FAIL", origin(1), err)
  763. }
  764. t.setErrno(err)
  765. return -1
  766. }
  767. if dmesgs {
  768. dmesg("%v: ok", origin(1))
  769. }
  770. return types.Pid_t(n)
  771. }
  772. // int uname(struct utsname *buf);
  773. func Xuname(t *TLS, buf uintptr) int32 {
  774. if __ccgo_strace {
  775. trc("t=%v buf=%v, (%v:)", t, buf, origin(2))
  776. }
  777. if err := unix.Uname((*unix.Utsname)(unsafe.Pointer(buf))); err != nil {
  778. if dmesgs {
  779. dmesg("%v: %v FAIL", origin(1), err)
  780. }
  781. t.setErrno(err)
  782. return -1
  783. }
  784. if dmesgs {
  785. dmesg("%v: ok", origin(1))
  786. }
  787. return 0
  788. }
  789. // ssize_t recv(int sockfd, void *buf, size_t len, int flags);
  790. func Xrecv(t *TLS, sockfd int32, buf uintptr, len types.Size_t, flags int32) types.Ssize_t {
  791. if __ccgo_strace {
  792. trc("t=%v sockfd=%v buf=%v len=%v flags=%v, (%v:)", t, sockfd, buf, len, flags, origin(2))
  793. }
  794. n, _, err := unix.Syscall6(unix.SYS_RECVFROM, uintptr(sockfd), buf, uintptr(len), uintptr(flags), 0, 0)
  795. if err != 0 {
  796. t.setErrno(err)
  797. return -1
  798. }
  799. return types.Ssize_t(n)
  800. }
  801. // ssize_t send(int sockfd, const void *buf, size_t len, int flags);
  802. func Xsend(t *TLS, sockfd int32, buf uintptr, len types.Size_t, flags int32) types.Ssize_t {
  803. if __ccgo_strace {
  804. trc("t=%v sockfd=%v buf=%v len=%v flags=%v, (%v:)", t, sockfd, buf, len, flags, origin(2))
  805. }
  806. n, _, err := unix.Syscall6(unix.SYS_SENDTO, uintptr(sockfd), buf, uintptr(len), uintptr(flags), 0, 0)
  807. if err != 0 {
  808. t.setErrno(err)
  809. return -1
  810. }
  811. return types.Ssize_t(n)
  812. }
  813. // int shutdown(int sockfd, int how);
  814. func Xshutdown(t *TLS, sockfd, how int32) int32 {
  815. if __ccgo_strace {
  816. trc("t=%v how=%v, (%v:)", t, how, origin(2))
  817. }
  818. if _, _, err := unix.Syscall(unix.SYS_SHUTDOWN, uintptr(sockfd), uintptr(how), 0); err != 0 {
  819. t.setErrno(err)
  820. return -1
  821. }
  822. return 0
  823. }
  824. // int getpeername(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
  825. func Xgetpeername(t *TLS, sockfd int32, addr uintptr, addrlen uintptr) int32 {
  826. if __ccgo_strace {
  827. trc("t=%v sockfd=%v addr=%v addrlen=%v, (%v:)", t, sockfd, addr, addrlen, origin(2))
  828. }
  829. if _, _, err := unix.Syscall(unix.SYS_GETPEERNAME, uintptr(sockfd), addr, uintptr(addrlen)); err != 0 {
  830. t.setErrno(err)
  831. return -1
  832. }
  833. return 0
  834. }
  835. // int socket(int domain, int type, int protocol);
  836. func Xsocket(t *TLS, domain, type1, protocol int32) int32 {
  837. if __ccgo_strace {
  838. trc("t=%v protocol=%v, (%v:)", t, protocol, origin(2))
  839. }
  840. n, _, err := unix.Syscall(unix.SYS_SOCKET, uintptr(domain), uintptr(type1), uintptr(protocol))
  841. if err != 0 {
  842. t.setErrno(err)
  843. return -1
  844. }
  845. return int32(n)
  846. }
  847. // int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
  848. func Xbind(t *TLS, sockfd int32, addr uintptr, addrlen uint32) int32 {
  849. if __ccgo_strace {
  850. trc("t=%v sockfd=%v addr=%v addrlen=%v, (%v:)", t, sockfd, addr, addrlen, origin(2))
  851. }
  852. n, _, err := unix.Syscall(unix.SYS_BIND, uintptr(sockfd), addr, uintptr(addrlen))
  853. if err != 0 {
  854. t.setErrno(err)
  855. return -1
  856. }
  857. return int32(n)
  858. }
  859. // int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
  860. func Xconnect(t *TLS, sockfd int32, addr uintptr, addrlen uint32) int32 {
  861. if __ccgo_strace {
  862. trc("t=%v sockfd=%v addr=%v addrlen=%v, (%v:)", t, sockfd, addr, addrlen, origin(2))
  863. }
  864. if _, _, err := unix.Syscall(unix.SYS_CONNECT, uintptr(sockfd), addr, uintptr(addrlen)); err != 0 {
  865. t.setErrno(err)
  866. return -1
  867. }
  868. return 0
  869. }
  870. // int listen(int sockfd, int backlog);
  871. func Xlisten(t *TLS, sockfd, backlog int32) int32 {
  872. if __ccgo_strace {
  873. trc("t=%v backlog=%v, (%v:)", t, backlog, origin(2))
  874. }
  875. if _, _, err := unix.Syscall(unix.SYS_LISTEN, uintptr(sockfd), uintptr(backlog), 0); err != 0 {
  876. t.setErrno(err)
  877. return -1
  878. }
  879. return 0
  880. }
  881. // int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
  882. func Xaccept(t *TLS, sockfd int32, addr uintptr, addrlen uintptr) int32 {
  883. if __ccgo_strace {
  884. trc("t=%v sockfd=%v addr=%v addrlen=%v, (%v:)", t, sockfd, addr, addrlen, origin(2))
  885. }
  886. panic(todo(""))
  887. // n, _, err := unix.Syscall6(unix.SYS_ACCEPT4, uintptr(sockfd), addr, uintptr(addrlen), 0, 0, 0)
  888. // if err != 0 {
  889. // t.setErrno(err)
  890. // return -1
  891. // }
  892. // return int32(n)
  893. }
  894. // // int getrlimit(int resource, struct rlimit *rlim);
  895. // func Xgetrlimit(t *TLS, resource int32, rlim uintptr) int32 {
  896. // return Xgetrlimit64(t, resource, rlim)
  897. // }
  898. //
  899. // // int setrlimit(int resource, const struct rlimit *rlim);
  900. // func Xsetrlimit(t *TLS, resource int32, rlim uintptr) int32 {
  901. // return Xsetrlimit64(t, resource, rlim)
  902. // }
  903. //
  904. // // int setrlimit(int resource, const struct rlimit *rlim);
  905. // func Xsetrlimit64(t *TLS, resource int32, rlim uintptr) int32 {
  906. // if _, _, err := unix.Syscall(unix.SYS_SETRLIMIT, uintptr(resource), uintptr(rlim), 0); err != 0 {
  907. // t.setErrno(err)
  908. // return -1
  909. // }
  910. //
  911. // return 0
  912. // }
  913. // uid_t getuid(void);
  914. func Xgetuid(t *TLS) types.Uid_t {
  915. if __ccgo_strace {
  916. trc("t=%v, (%v:)", t, origin(2))
  917. }
  918. r := types.Uid_t(os.Getuid())
  919. if dmesgs {
  920. dmesg("%v: %v", origin(1), r)
  921. }
  922. return r
  923. }
  924. // pid_t getpid(void);
  925. func Xgetpid(t *TLS) int32 {
  926. if __ccgo_strace {
  927. trc("t=%v, (%v:)", t, origin(2))
  928. }
  929. r := int32(os.Getpid())
  930. if dmesgs {
  931. dmesg("%v: %v", origin(1), r)
  932. }
  933. return r
  934. }
  935. // int system(const char *command);
  936. func Xsystem(t *TLS, command uintptr) int32 {
  937. if __ccgo_strace {
  938. trc("t=%v command=%v, (%v:)", t, command, origin(2))
  939. }
  940. s := GoString(command)
  941. if command == 0 {
  942. panic(todo(""))
  943. }
  944. cmd := exec.Command("sh", "-c", s)
  945. cmd.Stdout = os.Stdout
  946. cmd.Stderr = os.Stderr
  947. err := cmd.Run()
  948. if err != nil {
  949. ps := err.(*exec.ExitError)
  950. return int32(ps.ExitCode())
  951. }
  952. return 0
  953. }
  954. // int setvbuf(FILE *stream, char *buf, int mode, size_t size);
  955. func Xsetvbuf(t *TLS, stream, buf uintptr, mode int32, size types.Size_t) int32 {
  956. if __ccgo_strace {
  957. trc("t=%v buf=%v mode=%v size=%v, (%v:)", t, buf, mode, size, origin(2))
  958. }
  959. return 0 //TODO
  960. }
  961. // int raise(int sig);
  962. func Xraise(t *TLS, sig int32) int32 {
  963. if __ccgo_strace {
  964. trc("t=%v sig=%v, (%v:)", t, sig, origin(2))
  965. }
  966. panic(todo(""))
  967. }
  968. // // int backtrace(void **buffer, int size);
  969. // func Xbacktrace(t *TLS, buf uintptr, size int32) int32 {
  970. // panic(todo(""))
  971. // }
  972. //
  973. // // void backtrace_symbols_fd(void *const *buffer, int size, int fd);
  974. // func Xbacktrace_symbols_fd(t *TLS, buffer uintptr, size, fd int32) {
  975. // panic(todo(""))
  976. // }
  977. // int fileno(FILE *stream);
  978. func Xfileno(t *TLS, stream uintptr) int32 {
  979. if __ccgo_strace {
  980. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  981. }
  982. if stream == 0 {
  983. if dmesgs {
  984. dmesg("%v: FAIL", origin(1))
  985. }
  986. t.setErrno(errno.EBADF)
  987. return -1
  988. }
  989. if fd := int32((*stdio.FILE)(unsafe.Pointer(stream)).F_file); fd >= 0 {
  990. return fd
  991. }
  992. if dmesgs {
  993. dmesg("%v: FAIL", origin(1))
  994. }
  995. t.setErrno(errno.EBADF)
  996. return -1
  997. }
  998. func newFtsent(t *TLS, info int, path string, stat *unix.Stat_t, err syscallErrno) (r *fts.FTSENT) {
  999. var statp uintptr
  1000. if stat != nil {
  1001. statp = Xmalloc(t, types.Size_t(unsafe.Sizeof(unix.Stat_t{})))
  1002. if statp == 0 {
  1003. panic("OOM")
  1004. }
  1005. *(*unix.Stat_t)(unsafe.Pointer(statp)) = *stat
  1006. }
  1007. csp, errx := CString(path)
  1008. if errx != nil {
  1009. panic("OOM")
  1010. }
  1011. return &fts.FTSENT{
  1012. Ffts_info: uint16(info),
  1013. Ffts_path: csp,
  1014. Ffts_pathlen: uint16(len(path)),
  1015. Ffts_statp: statp,
  1016. Ffts_errno: int32(err),
  1017. }
  1018. }
  1019. func newCFtsent(t *TLS, info int, path string, stat *unix.Stat_t, err syscallErrno) uintptr {
  1020. p := Xcalloc(t, 1, types.Size_t(unsafe.Sizeof(fts.FTSENT{})))
  1021. if p == 0 {
  1022. panic("OOM")
  1023. }
  1024. *(*fts.FTSENT)(unsafe.Pointer(p)) = *newFtsent(t, info, path, stat, err)
  1025. return p
  1026. }
  1027. func ftsentClose(t *TLS, p uintptr) {
  1028. Xfree(t, (*fts.FTSENT)(unsafe.Pointer(p)).Ffts_path)
  1029. Xfree(t, (*fts.FTSENT)(unsafe.Pointer(p)).Ffts_statp)
  1030. }
  1031. type ftstream struct {
  1032. s []uintptr
  1033. x int
  1034. }
  1035. func (f *ftstream) close(t *TLS) {
  1036. for _, p := range f.s {
  1037. ftsentClose(t, p)
  1038. Xfree(t, p)
  1039. }
  1040. *f = ftstream{}
  1041. }
  1042. // FTS *fts_open(char * const *path_argv, int options, int (*compar)(const FTSENT **, const FTSENT **));
  1043. func Xfts_open(t *TLS, path_argv uintptr, options int32, compar uintptr) uintptr {
  1044. if __ccgo_strace {
  1045. trc("t=%v path_argv=%v options=%v compar=%v, (%v:)", t, path_argv, options, compar, origin(2))
  1046. }
  1047. f := &ftstream{}
  1048. var walk func(string)
  1049. walk = func(path string) {
  1050. var fi os.FileInfo
  1051. var err error
  1052. switch {
  1053. case options&fts.FTS_LOGICAL != 0:
  1054. fi, err = os.Stat(path)
  1055. case options&fts.FTS_PHYSICAL != 0:
  1056. fi, err = os.Lstat(path)
  1057. default:
  1058. panic(todo(""))
  1059. }
  1060. if err != nil {
  1061. return
  1062. }
  1063. var statp *unix.Stat_t
  1064. if options&fts.FTS_NOSTAT == 0 {
  1065. var stat unix.Stat_t
  1066. switch {
  1067. case options&fts.FTS_LOGICAL != 0:
  1068. if err := unix.Stat(path, &stat); err != nil {
  1069. panic(todo(""))
  1070. }
  1071. case options&fts.FTS_PHYSICAL != 0:
  1072. if err := unix.Lstat(path, &stat); err != nil {
  1073. panic(todo(""))
  1074. }
  1075. default:
  1076. panic(todo(""))
  1077. }
  1078. statp = &stat
  1079. }
  1080. out:
  1081. switch {
  1082. case fi.IsDir():
  1083. f.s = append(f.s, newCFtsent(t, fts.FTS_D, path, statp, 0))
  1084. g, err := os.Open(path)
  1085. switch x := err.(type) {
  1086. case nil:
  1087. // ok
  1088. case *os.PathError:
  1089. f.s = append(f.s, newCFtsent(t, fts.FTS_DNR, path, statp, errno.EACCES))
  1090. break out
  1091. default:
  1092. panic(todo("%q: %v %T", path, x, x))
  1093. }
  1094. names, err := g.Readdirnames(-1)
  1095. g.Close()
  1096. if err != nil {
  1097. panic(todo(""))
  1098. }
  1099. for _, name := range names {
  1100. walk(path + "/" + name)
  1101. if f == nil {
  1102. break out
  1103. }
  1104. }
  1105. f.s = append(f.s, newCFtsent(t, fts.FTS_DP, path, statp, 0))
  1106. default:
  1107. info := fts.FTS_F
  1108. if fi.Mode()&os.ModeSymlink != 0 {
  1109. info = fts.FTS_SL
  1110. }
  1111. switch {
  1112. case statp != nil:
  1113. f.s = append(f.s, newCFtsent(t, info, path, statp, 0))
  1114. case options&fts.FTS_NOSTAT != 0:
  1115. f.s = append(f.s, newCFtsent(t, fts.FTS_NSOK, path, nil, 0))
  1116. default:
  1117. panic(todo(""))
  1118. }
  1119. }
  1120. }
  1121. for {
  1122. p := *(*uintptr)(unsafe.Pointer(path_argv))
  1123. if p == 0 {
  1124. if f == nil {
  1125. return 0
  1126. }
  1127. if compar != 0 {
  1128. panic(todo(""))
  1129. }
  1130. return addObject(f)
  1131. }
  1132. walk(GoString(p))
  1133. path_argv += unsafe.Sizeof(uintptr(0))
  1134. }
  1135. }
  1136. // FTSENT *fts_read(FTS *ftsp);
  1137. func Xfts_read(t *TLS, ftsp uintptr) uintptr {
  1138. if __ccgo_strace {
  1139. trc("t=%v ftsp=%v, (%v:)", t, ftsp, origin(2))
  1140. }
  1141. f := getObject(ftsp).(*ftstream)
  1142. if f.x == len(f.s) {
  1143. if dmesgs {
  1144. dmesg("%v: FAIL", origin(1))
  1145. }
  1146. t.setErrno(0)
  1147. return 0
  1148. }
  1149. r := f.s[f.x]
  1150. if e := (*fts.FTSENT)(unsafe.Pointer(r)).Ffts_errno; e != 0 {
  1151. if dmesgs {
  1152. dmesg("%v: FAIL", origin(1))
  1153. }
  1154. t.setErrno(e)
  1155. }
  1156. f.x++
  1157. return r
  1158. }
  1159. // int fts_close(FTS *ftsp);
  1160. func Xfts_close(t *TLS, ftsp uintptr) int32 {
  1161. if __ccgo_strace {
  1162. trc("t=%v ftsp=%v, (%v:)", t, ftsp, origin(2))
  1163. }
  1164. getObject(ftsp).(*ftstream).close(t)
  1165. removeObject(ftsp)
  1166. return 0
  1167. }
  1168. // void tzset (void);
  1169. func Xtzset(t *TLS) {
  1170. if __ccgo_strace {
  1171. trc("t=%v, (%v:)", t, origin(2))
  1172. }
  1173. //TODO
  1174. }
  1175. var strerrorBuf [100]byte
  1176. // char *strerror(int errnum);
  1177. func Xstrerror(t *TLS, errnum int32) uintptr {
  1178. if __ccgo_strace {
  1179. trc("t=%v errnum=%v, (%v:)", t, errnum, origin(2))
  1180. }
  1181. // if dmesgs {
  1182. // dmesg("%v: %v\n%s", origin(1), errnum, debug.Stack())
  1183. // }
  1184. copy(strerrorBuf[:], fmt.Sprintf("strerror(%d)\x00", errnum))
  1185. return uintptr(unsafe.Pointer(&strerrorBuf[0]))
  1186. }
  1187. // void *dlopen(const char *filename, int flags);
  1188. func Xdlopen(t *TLS, filename uintptr, flags int32) uintptr {
  1189. if __ccgo_strace {
  1190. trc("t=%v filename=%v flags=%v, (%v:)", t, filename, flags, origin(2))
  1191. }
  1192. panic(todo(""))
  1193. }
  1194. // char *dlerror(void);
  1195. func Xdlerror(t *TLS) uintptr {
  1196. if __ccgo_strace {
  1197. trc("t=%v, (%v:)", t, origin(2))
  1198. }
  1199. panic(todo(""))
  1200. }
  1201. // int dlclose(void *handle);
  1202. func Xdlclose(t *TLS, handle uintptr) int32 {
  1203. if __ccgo_strace {
  1204. trc("t=%v handle=%v, (%v:)", t, handle, origin(2))
  1205. }
  1206. panic(todo(""))
  1207. }
  1208. // void *dlsym(void *handle, const char *symbol);
  1209. func Xdlsym(t *TLS, handle, symbol uintptr) uintptr {
  1210. if __ccgo_strace {
  1211. trc("t=%v symbol=%v, (%v:)", t, symbol, origin(2))
  1212. }
  1213. panic(todo(""))
  1214. }
  1215. // void perror(const char *s);
  1216. func Xperror(t *TLS, s uintptr) {
  1217. if __ccgo_strace {
  1218. trc("t=%v s=%v, (%v:)", t, s, origin(2))
  1219. }
  1220. panic(todo(""))
  1221. }
  1222. // int pclose(FILE *stream);
  1223. func Xpclose(t *TLS, stream uintptr) int32 {
  1224. if __ccgo_strace {
  1225. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1226. }
  1227. panic(todo(""))
  1228. }
  1229. // var gai_strerrorBuf [100]byte
  1230. // const char *gai_strerror(int errcode);
  1231. func Xgai_strerror(t *TLS, errcode int32) uintptr {
  1232. if __ccgo_strace {
  1233. trc("t=%v errcode=%v, (%v:)", t, errcode, origin(2))
  1234. }
  1235. panic(todo(""))
  1236. // copy(gai_strerrorBuf[:], fmt.Sprintf("gai error %d\x00", errcode))
  1237. // return uintptr(unsafe.Pointer(&gai_strerrorBuf))
  1238. }
  1239. // int tcgetattr(int fd, struct termios *termios_p);
  1240. func Xtcgetattr(t *TLS, fd int32, termios_p uintptr) int32 {
  1241. if __ccgo_strace {
  1242. trc("t=%v fd=%v termios_p=%v, (%v:)", t, fd, termios_p, origin(2))
  1243. }
  1244. panic(todo(""))
  1245. }
  1246. // int tcsetattr(int fd, int optional_actions, const struct termios *termios_p);
  1247. func Xtcsetattr(t *TLS, fd, optional_actions int32, termios_p uintptr) int32 {
  1248. if __ccgo_strace {
  1249. trc("t=%v optional_actions=%v termios_p=%v, (%v:)", t, optional_actions, termios_p, origin(2))
  1250. }
  1251. panic(todo(""))
  1252. }
  1253. // speed_t cfgetospeed(const struct termios *termios_p);
  1254. func Xcfgetospeed(t *TLS, termios_p uintptr) termios.Speed_t {
  1255. if __ccgo_strace {
  1256. trc("t=%v termios_p=%v, (%v:)", t, termios_p, origin(2))
  1257. }
  1258. panic(todo(""))
  1259. }
  1260. // int cfsetospeed(struct termios *termios_p, speed_t speed);
  1261. // func Xcfsetospeed(t *TLS, termios_p uintptr, speed uint32) int32 {
  1262. func Xcfsetospeed(...interface{}) int32 {
  1263. panic(todo(""))
  1264. }
  1265. // int cfsetispeed(struct termios *termios_p, speed_t speed);
  1266. // func Xcfsetispeed(t *TLS, termios_p uintptr, speed uint32) int32 {
  1267. func Xcfsetispeed(...interface{}) int32 {
  1268. panic(todo(""))
  1269. }
  1270. // pid_t fork(void);
  1271. func Xfork(t *TLS) int32 {
  1272. if __ccgo_strace {
  1273. trc("t=%v, (%v:)", t, origin(2))
  1274. }
  1275. if dmesgs {
  1276. dmesg("%v: FAIL", origin(1))
  1277. }
  1278. t.setErrno(errno.ENOSYS)
  1279. return -1
  1280. }
  1281. var emptyStr = [1]byte{}
  1282. // char *setlocale(int category, const char *locale);
  1283. func Xsetlocale(t *TLS, category int32, locale uintptr) uintptr {
  1284. if __ccgo_strace {
  1285. trc("t=%v category=%v locale=%v, (%v:)", t, category, locale, origin(2))
  1286. }
  1287. return uintptr(unsafe.Pointer(&emptyStr)) //TODO
  1288. }
  1289. // char *nl_langinfo(nl_item item);
  1290. func Xnl_langinfo(t *TLS, item langinfo.Nl_item) uintptr {
  1291. if __ccgo_strace {
  1292. trc("t=%v item=%v, (%v:)", t, item, origin(2))
  1293. }
  1294. return uintptr(unsafe.Pointer(&emptyStr)) //TODO
  1295. }
  1296. // FILE *popen(const char *command, const char *type);
  1297. func Xpopen(t *TLS, command, type1 uintptr) uintptr {
  1298. if __ccgo_strace {
  1299. trc("t=%v type1=%v, (%v:)", t, type1, origin(2))
  1300. }
  1301. panic(todo(""))
  1302. }
  1303. // char *realpath(const char *path, char *resolved_path);
  1304. func Xrealpath(t *TLS, path, resolved_path uintptr) uintptr {
  1305. if __ccgo_strace {
  1306. trc("t=%v resolved_path=%v, (%v:)", t, resolved_path, origin(2))
  1307. }
  1308. s, err := filepath.EvalSymlinks(GoString(path))
  1309. if err != nil {
  1310. if os.IsNotExist(err) {
  1311. if dmesgs {
  1312. dmesg("%v: %q: %v FAIL", origin(1), GoString(path), err)
  1313. }
  1314. t.setErrno(errno.ENOENT)
  1315. return 0
  1316. }
  1317. panic(todo("", err))
  1318. }
  1319. if resolved_path == 0 {
  1320. panic(todo(""))
  1321. }
  1322. if len(s) >= limits.PATH_MAX {
  1323. s = s[:limits.PATH_MAX-1]
  1324. }
  1325. copy((*RawMem)(unsafe.Pointer(resolved_path))[:len(s):len(s)], s)
  1326. (*RawMem)(unsafe.Pointer(resolved_path))[len(s)] = 0
  1327. if dmesgs {
  1328. dmesg("%v: %q: ok", origin(1), GoString(path))
  1329. }
  1330. return resolved_path
  1331. }
  1332. // char *inet_ntoa(struct in_addr in);
  1333. func Xinet_ntoa(t *TLS, in1 in.In_addr) uintptr {
  1334. if __ccgo_strace {
  1335. trc("t=%v in1=%v, (%v:)", t, in1, origin(2))
  1336. }
  1337. panic(todo(""))
  1338. }
  1339. func X__ccgo_in6addr_anyp(t *TLS) uintptr {
  1340. if __ccgo_strace {
  1341. trc("t=%v, (%v:)", t, origin(2))
  1342. }
  1343. panic(todo(""))
  1344. // return uintptr(unsafe.Pointer(&in6_addr_any))
  1345. }
  1346. func Xabort(t *TLS) {
  1347. if __ccgo_strace {
  1348. trc("t=%v, (%v:)", t, origin(2))
  1349. }
  1350. if dmesgs {
  1351. dmesg("%v:", origin(1))
  1352. }
  1353. p := Xcalloc(t, 1, types.Size_t(unsafe.Sizeof(signal.Sigaction{})))
  1354. if p == 0 {
  1355. panic("OOM")
  1356. }
  1357. (*signal.Sigaction)(unsafe.Pointer(p)).F__sigaction_u.F__sa_handler = signal.SIG_DFL
  1358. Xsigaction(t, signal.SIGABRT, p, 0)
  1359. Xfree(t, p)
  1360. unix.Kill(unix.Getpid(), unix.Signal(signal.SIGABRT))
  1361. panic(todo("unrechable"))
  1362. }
  1363. // int fflush(FILE *stream);
  1364. func Xfflush(t *TLS, stream uintptr) int32 {
  1365. if __ccgo_strace {
  1366. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1367. }
  1368. return 0 //TODO
  1369. }
  1370. // size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
  1371. func Xfread(t *TLS, ptr uintptr, size, nmemb types.Size_t, stream uintptr) types.Size_t {
  1372. if __ccgo_strace {
  1373. trc("t=%v ptr=%v nmemb=%v stream=%v, (%v:)", t, ptr, nmemb, stream, origin(2))
  1374. }
  1375. fd := uintptr(file(stream).fd())
  1376. count := size * nmemb
  1377. var n int
  1378. var err error
  1379. switch {
  1380. case count == 0:
  1381. n, err = unix.Read(int(fd), nil)
  1382. default:
  1383. n, err = unix.Read(int(fd), (*RawMem)(unsafe.Pointer(ptr))[:count:count])
  1384. if n == 0 {
  1385. file(stream).setEOF()
  1386. }
  1387. if dmesgs && err == nil {
  1388. dmesg("%v: fd %v, n %#x\n%s", origin(1), fd, n, hex.Dump((*RawMem)(unsafe.Pointer(ptr))[:n:n]))
  1389. }
  1390. }
  1391. if err != nil {
  1392. if dmesgs {
  1393. dmesg("%v: %v FAIL", origin(1), err)
  1394. }
  1395. file(stream).setErr()
  1396. return types.Size_t(n) / size
  1397. }
  1398. if dmesgs {
  1399. dmesg("%v: ok", origin(1))
  1400. }
  1401. return types.Size_t(n) / size
  1402. }
  1403. // size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);
  1404. func Xfwrite(t *TLS, ptr uintptr, size, nmemb types.Size_t, stream uintptr) types.Size_t {
  1405. if __ccgo_strace {
  1406. trc("t=%v ptr=%v nmemb=%v stream=%v, (%v:)", t, ptr, nmemb, stream, origin(2))
  1407. }
  1408. fd := uintptr(file(stream).fd())
  1409. count := size * nmemb
  1410. var n int
  1411. var err error
  1412. switch {
  1413. case count == 0:
  1414. n, err = unix.Write(int(fd), nil)
  1415. default:
  1416. n, err = unix.Write(int(fd), (*RawMem)(unsafe.Pointer(ptr))[:count:count])
  1417. if dmesgs {
  1418. dmesg("%v: fd %v, count %#x\n%s", origin(1), fd, count, hex.Dump((*RawMem)(unsafe.Pointer(ptr))[:count:count]))
  1419. }
  1420. }
  1421. if err != nil {
  1422. if dmesgs {
  1423. dmesg("%v: %v FAIL", origin(1), err)
  1424. }
  1425. file(stream).setErr()
  1426. return types.Size_t(n) / size
  1427. }
  1428. if dmesgs {
  1429. dmesg("%v: ok", origin(1))
  1430. }
  1431. return types.Size_t(n) / size
  1432. }
  1433. // int fclose(FILE *stream);
  1434. func Xfclose(t *TLS, stream uintptr) int32 {
  1435. if __ccgo_strace {
  1436. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1437. }
  1438. r := file(stream).close(t)
  1439. if r != 0 {
  1440. if dmesgs {
  1441. dmesg("%v: %v FAIL", origin(1), r)
  1442. }
  1443. t.setErrno(r)
  1444. return stdio.EOF
  1445. }
  1446. if dmesgs {
  1447. dmesg("%v: ok", origin(1))
  1448. }
  1449. return 0
  1450. }
  1451. // int fputc(int c, FILE *stream);
  1452. func Xfputc(t *TLS, c int32, stream uintptr) int32 {
  1453. if __ccgo_strace {
  1454. trc("t=%v c=%v stream=%v, (%v:)", t, c, stream, origin(2))
  1455. }
  1456. if _, err := fwrite(file(stream).fd(), []byte{byte(c)}); err != nil {
  1457. return stdio.EOF
  1458. }
  1459. return int32(byte(c))
  1460. }
  1461. // int fseek(FILE *stream, long offset, int whence);
  1462. func Xfseek(t *TLS, stream uintptr, offset long, whence int32) int32 {
  1463. if __ccgo_strace {
  1464. trc("t=%v stream=%v offset=%v whence=%v, (%v:)", t, stream, offset, whence, origin(2))
  1465. }
  1466. if n := Xlseek(t, int32(file(stream).fd()), types.Off_t(offset), whence); n < 0 {
  1467. if dmesgs {
  1468. dmesg("%v: fd %v, off %#x, whence %v: %v", origin(1), file(stream).fd(), offset, whenceStr(whence), n)
  1469. }
  1470. file(stream).setErr()
  1471. return -1
  1472. }
  1473. if dmesgs {
  1474. dmesg("%v: fd %v, off %#x, whence %v: ok", origin(1), file(stream).fd(), offset, whenceStr(whence))
  1475. }
  1476. return 0
  1477. }
  1478. // long ftell(FILE *stream);
  1479. func Xftell(t *TLS, stream uintptr) long {
  1480. if __ccgo_strace {
  1481. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1482. }
  1483. n := Xlseek(t, file(stream).fd(), 0, stdio.SEEK_CUR)
  1484. if n < 0 {
  1485. file(stream).setErr()
  1486. return -1
  1487. }
  1488. if dmesgs {
  1489. dmesg("%v: fd %v, n %#x: ok %#x", origin(1), file(stream).fd(), n, long(n))
  1490. }
  1491. return long(n)
  1492. }
  1493. // int ferror(FILE *stream);
  1494. func Xferror(t *TLS, stream uintptr) int32 {
  1495. if __ccgo_strace {
  1496. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1497. }
  1498. return Bool32(file(stream).err())
  1499. }
  1500. // int fputs(const char *s, FILE *stream);
  1501. func Xfputs(t *TLS, s, stream uintptr) int32 {
  1502. if __ccgo_strace {
  1503. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1504. }
  1505. if _, _, err := unix.Syscall(unix.SYS_WRITE, uintptr(file(stream).fd()), s, uintptr(Xstrlen(t, s))); err != 0 {
  1506. return -1
  1507. }
  1508. return 0
  1509. }
  1510. var getservbynameStaticResult netdb.Servent
  1511. // struct servent *getservbyname(const char *name, const char *proto);
  1512. func Xgetservbyname(t *TLS, name, proto uintptr) uintptr {
  1513. if __ccgo_strace {
  1514. trc("t=%v proto=%v, (%v:)", t, proto, origin(2))
  1515. }
  1516. var protoent *gonetdb.Protoent
  1517. if proto != 0 {
  1518. protoent = gonetdb.GetProtoByName(GoString(proto))
  1519. }
  1520. servent := gonetdb.GetServByName(GoString(name), protoent)
  1521. if servent == nil {
  1522. if dmesgs {
  1523. dmesg("%q %q: nil (protoent %+v)", GoString(name), GoString(proto), protoent)
  1524. }
  1525. return 0
  1526. }
  1527. Xfree(t, (*netdb.Servent)(unsafe.Pointer(&getservbynameStaticResult)).Fs_name)
  1528. if v := (*netdb.Servent)(unsafe.Pointer(&getservbynameStaticResult)).Fs_aliases; v != 0 {
  1529. for {
  1530. p := *(*uintptr)(unsafe.Pointer(v))
  1531. if p == 0 {
  1532. break
  1533. }
  1534. Xfree(t, p)
  1535. v += unsafe.Sizeof(uintptr(0))
  1536. }
  1537. Xfree(t, v)
  1538. }
  1539. Xfree(t, (*netdb.Servent)(unsafe.Pointer(&getservbynameStaticResult)).Fs_proto)
  1540. cname, err := CString(servent.Name)
  1541. if err != nil {
  1542. getservbynameStaticResult = netdb.Servent{}
  1543. return 0
  1544. }
  1545. var protoname uintptr
  1546. if protoent != nil {
  1547. if protoname, err = CString(protoent.Name); err != nil {
  1548. Xfree(t, cname)
  1549. getservbynameStaticResult = netdb.Servent{}
  1550. return 0
  1551. }
  1552. }
  1553. var a []uintptr
  1554. for _, v := range servent.Aliases {
  1555. cs, err := CString(v)
  1556. if err != nil {
  1557. for _, v := range a {
  1558. Xfree(t, v)
  1559. }
  1560. return 0
  1561. }
  1562. a = append(a, cs)
  1563. }
  1564. v := Xcalloc(t, types.Size_t(len(a)+1), types.Size_t(unsafe.Sizeof(uintptr(0))))
  1565. if v == 0 {
  1566. Xfree(t, cname)
  1567. Xfree(t, protoname)
  1568. for _, v := range a {
  1569. Xfree(t, v)
  1570. }
  1571. getservbynameStaticResult = netdb.Servent{}
  1572. return 0
  1573. }
  1574. for _, p := range a {
  1575. *(*uintptr)(unsafe.Pointer(v)) = p
  1576. v += unsafe.Sizeof(uintptr(0))
  1577. }
  1578. getservbynameStaticResult = netdb.Servent{
  1579. Fs_name: cname,
  1580. Fs_aliases: v,
  1581. Fs_port: int32(servent.Port),
  1582. Fs_proto: protoname,
  1583. }
  1584. return uintptr(unsafe.Pointer(&getservbynameStaticResult))
  1585. }
  1586. // //TODO- func Xreaddir64(t *TLS, dir uintptr) uintptr {
  1587. // //TODO- return Xreaddir(t, dir)
  1588. // //TODO- }
  1589. //
  1590. // func __syscall(r, _ uintptr, errno syscallErrno) long {
  1591. // if errno != 0 {
  1592. // return long(-errno)
  1593. // }
  1594. //
  1595. // return long(r)
  1596. // }
  1597. func fcntlCmdStr(cmd int32) string {
  1598. switch cmd {
  1599. case fcntl.F_GETOWN:
  1600. return "F_GETOWN"
  1601. case fcntl.F_SETLK:
  1602. return "F_SETLK"
  1603. case fcntl.F_GETLK:
  1604. return "F_GETLK"
  1605. case fcntl.F_SETFD:
  1606. return "F_SETFD"
  1607. case fcntl.F_GETFD:
  1608. return "F_GETFD"
  1609. default:
  1610. return fmt.Sprintf("cmd(%d)", cmd)
  1611. }
  1612. }
  1613. // // struct __float2 { float __sinval; float __cosval; };
  1614. // // struct __double2 { double __sinval; double __cosval; };
  1615. // //
  1616. // // extern struct __float2 __sincosf_stret(float);
  1617. // // extern struct __double2 __sincos_stret(double);
  1618. // // extern struct __float2 __sincospif_stret(float);
  1619. // // extern struct __double2 __sincospi_stret(double);
  1620. //
  1621. // type X__float2 struct{ F__sinval, F__cosval float32 }
  1622. // type X__double2 struct{ F__sinval, F__cosval float32 }
  1623. //
  1624. // func X__sincosf_stret(*TLS, float32) X__float2 {
  1625. // panic(todo(""))
  1626. // }
  1627. //
  1628. // func X__sincos_stret(*TLS, float64) X__double2 {
  1629. // panic(todo(""))
  1630. // }
  1631. //
  1632. // func X__sincospif_stret(*TLS, float32) X__float2 {
  1633. // panic(todo(""))
  1634. // }
  1635. //
  1636. // func X__sincospi_stret(*TLS, float64) X__double2 {
  1637. // panic(todo(""))
  1638. // }
  1639. // ssize_t pwrite(int fd, const void *buf, size_t count, off_t offset);
  1640. func Xpwrite(t *TLS, fd int32, buf uintptr, count types.Size_t, offset types.Off_t) types.Ssize_t {
  1641. if __ccgo_strace {
  1642. trc("t=%v fd=%v buf=%v count=%v offset=%v, (%v:)", t, fd, buf, count, offset, origin(2))
  1643. }
  1644. var n int
  1645. var err error
  1646. switch {
  1647. case count == 0:
  1648. n, err = unix.Pwrite(int(fd), nil, int64(offset))
  1649. default:
  1650. n, err = unix.Pwrite(int(fd), (*RawMem)(unsafe.Pointer(buf))[:count:count], int64(offset))
  1651. if dmesgs {
  1652. dmesg("%v: fd %v, off %#x, count %#x\n%s", origin(1), fd, offset, count, hex.Dump((*RawMem)(unsafe.Pointer(buf))[:count:count]))
  1653. }
  1654. }
  1655. if err != nil {
  1656. if dmesgs {
  1657. dmesg("%v: %v FAIL", origin(1), err)
  1658. }
  1659. t.setErrno(err)
  1660. return -1
  1661. }
  1662. if dmesgs {
  1663. dmesg("%v: ok", origin(1))
  1664. }
  1665. return types.Ssize_t(n)
  1666. }
  1667. // char***_NSGetEnviron()
  1668. func X_NSGetEnviron(t *TLS) uintptr {
  1669. if __ccgo_strace {
  1670. trc("t=%v, (%v:)", t, origin(2))
  1671. }
  1672. return EnvironP()
  1673. }
  1674. // int chflags(const char *path, u_int flags);
  1675. func Xchflags(t *TLS, path uintptr, flags uint32) int32 {
  1676. if __ccgo_strace {
  1677. trc("t=%v path=%v flags=%v, (%v:)", t, path, flags, origin(2))
  1678. }
  1679. if err := unix.Chflags(GoString(path), int(flags)); err != nil {
  1680. if dmesgs {
  1681. dmesg("%v: %v FAIL", origin(1), err)
  1682. }
  1683. t.setErrno(err)
  1684. return -1
  1685. }
  1686. if dmesgs {
  1687. dmesg("%v: ok", origin(1))
  1688. }
  1689. return 0
  1690. }
  1691. // int rmdir(const char *pathname);
  1692. func Xrmdir(t *TLS, pathname uintptr) int32 {
  1693. if __ccgo_strace {
  1694. trc("t=%v pathname=%v, (%v:)", t, pathname, origin(2))
  1695. }
  1696. if err := unix.Rmdir(GoString(pathname)); err != nil {
  1697. if dmesgs {
  1698. dmesg("%v: %v FAIL", origin(1), err)
  1699. }
  1700. t.setErrno(err)
  1701. return -1
  1702. }
  1703. if dmesgs {
  1704. dmesg("%v: ok", origin(1))
  1705. }
  1706. return 0
  1707. }
  1708. // uint64_t mach_absolute_time(void);
  1709. func Xmach_absolute_time(t *TLS) uint64 {
  1710. if __ccgo_strace {
  1711. trc("t=%v, (%v:)", t, origin(2))
  1712. }
  1713. return uint64(gotime.Now().UnixNano())
  1714. }
  1715. // See https://developer.apple.com/library/archive/qa/qa1398/_index.html
  1716. type machTimebaseInfo = struct {
  1717. Fnumer uint32
  1718. Fdenom uint32
  1719. } /* mach_time.h:36:1 */
  1720. // kern_return_t mach_timebase_info(mach_timebase_info_t info);
  1721. func Xmach_timebase_info(t *TLS, info uintptr) int32 {
  1722. if __ccgo_strace {
  1723. trc("t=%v info=%v, (%v:)", t, info, origin(2))
  1724. }
  1725. *(*machTimebaseInfo)(unsafe.Pointer(info)) = machTimebaseInfo{Fnumer: 1, Fdenom: 1}
  1726. return 0
  1727. }
  1728. // int getattrlist(const char* path, struct attrlist * attrList, void * attrBuf, size_t attrBufSize, unsigned long options);
  1729. func Xgetattrlist(t *TLS, path, attrList, attrBuf uintptr, attrBufSize types.Size_t, options uint32) int32 {
  1730. if __ccgo_strace {
  1731. trc("t=%v attrBuf=%v attrBufSize=%v options=%v, (%v:)", t, attrBuf, attrBufSize, options, origin(2))
  1732. }
  1733. if _, _, err := unix.Syscall6(unix.SYS_GETATTRLIST, path, attrList, attrBuf, uintptr(attrBufSize), uintptr(options), 0); err != 0 { // Cannot avoid the syscall here.
  1734. if dmesgs {
  1735. dmesg("%v: %v FAIL", origin(1), err)
  1736. }
  1737. t.setErrno(err)
  1738. return -1
  1739. }
  1740. if dmesgs {
  1741. dmesg("%v: ok", origin(1))
  1742. }
  1743. return 0
  1744. }
  1745. // int setattrlist(const char* path, struct attrlist * attrList, void * attrBuf, size_t attrBufSize, unsigned long options);
  1746. func Xsetattrlist(t *TLS, path, attrList, attrBuf uintptr, attrBufSize types.Size_t, options uint32) int32 {
  1747. if __ccgo_strace {
  1748. trc("t=%v attrBuf=%v attrBufSize=%v options=%v, (%v:)", t, attrBuf, attrBufSize, options, origin(2))
  1749. }
  1750. if _, _, err := unix.Syscall6(unix.SYS_SETATTRLIST, path, attrList, attrBuf, uintptr(attrBufSize), uintptr(options), 0); err != 0 { // Cannot avoid the syscall here.
  1751. if dmesgs {
  1752. dmesg("%v: %v FAIL", origin(1), err)
  1753. }
  1754. t.setErrno(err)
  1755. return -1
  1756. }
  1757. if dmesgs {
  1758. dmesg("%v: ok", origin(1))
  1759. }
  1760. return 0
  1761. }
  1762. // int copyfile(const char *from, const char *to, copyfile_state_t state, copyfile_flags_t flags);
  1763. func Xcopyfile(t *TLS, _ ...interface{}) int32 {
  1764. panic(todo(""))
  1765. }
  1766. // int truncate(const char *path, off_t length);
  1767. func Xtruncate(t *TLS, _ ...interface{}) int32 {
  1768. panic(todo(""))
  1769. }
  1770. type darwinDir struct {
  1771. buf [4096]byte
  1772. fd int
  1773. h int
  1774. l int
  1775. eof bool
  1776. }
  1777. // DIR *opendir(const char *name);
  1778. func Xopendir(t *TLS, name uintptr) uintptr {
  1779. if __ccgo_strace {
  1780. trc("t=%v name=%v, (%v:)", t, name, origin(2))
  1781. }
  1782. p := Xmalloc(t, uint64(unsafe.Sizeof(darwinDir{})))
  1783. if p == 0 {
  1784. panic("OOM")
  1785. }
  1786. fd := int(Xopen(t, name, fcntl.O_RDONLY|fcntl.O_DIRECTORY|fcntl.O_CLOEXEC, 0))
  1787. if fd < 0 {
  1788. if dmesgs {
  1789. dmesg("%v: FAIL %v", origin(1), (*darwinDir)(unsafe.Pointer(p)).fd)
  1790. }
  1791. Xfree(t, p)
  1792. // trc("==== opendir: %#x", 0)
  1793. return 0
  1794. }
  1795. if dmesgs {
  1796. dmesg("%v: ok", origin(1))
  1797. }
  1798. (*darwinDir)(unsafe.Pointer(p)).fd = fd
  1799. (*darwinDir)(unsafe.Pointer(p)).h = 0
  1800. (*darwinDir)(unsafe.Pointer(p)).l = 0
  1801. (*darwinDir)(unsafe.Pointer(p)).eof = false
  1802. // trc("==== opendir: %#x", p)
  1803. return p
  1804. }
  1805. // struct dirent *readdir(DIR *dirp);
  1806. func Xreaddir(t *TLS, dir uintptr) uintptr {
  1807. if __ccgo_strace {
  1808. trc("t=%v dir=%v, (%v:)", t, dir, origin(2))
  1809. }
  1810. if (*darwinDir)(unsafe.Pointer(dir)).eof {
  1811. return 0
  1812. }
  1813. // trc(".... readdir %#x: l %v, h %v", dir, (*darwinDir)(unsafe.Pointer(dir)).l, (*darwinDir)(unsafe.Pointer(dir)).h)
  1814. if (*darwinDir)(unsafe.Pointer(dir)).l == (*darwinDir)(unsafe.Pointer(dir)).h {
  1815. n, err := unix.Getdirentries((*darwinDir)(unsafe.Pointer(dir)).fd, (*darwinDir)(unsafe.Pointer(dir)).buf[:], nil)
  1816. // trc("must read: %v %v", n, err)
  1817. if n == 0 {
  1818. if err != nil && err != io.EOF {
  1819. if dmesgs {
  1820. dmesg("%v: %v FAIL", origin(1), err)
  1821. }
  1822. t.setErrno(err)
  1823. }
  1824. (*darwinDir)(unsafe.Pointer(dir)).eof = true
  1825. return 0
  1826. }
  1827. (*darwinDir)(unsafe.Pointer(dir)).l = 0
  1828. (*darwinDir)(unsafe.Pointer(dir)).h = n
  1829. // trc("new l %v, h %v", (*darwinDir)(unsafe.Pointer(dir)).l, (*darwinDir)(unsafe.Pointer(dir)).h)
  1830. }
  1831. de := dir + unsafe.Offsetof(darwinDir{}.buf) + uintptr((*darwinDir)(unsafe.Pointer(dir)).l)
  1832. // trc("dir %#x de %#x", dir, de)
  1833. (*darwinDir)(unsafe.Pointer(dir)).l += int((*unix.Dirent)(unsafe.Pointer(de)).Reclen)
  1834. // trc("final l %v, h %v", (*darwinDir)(unsafe.Pointer(dir)).l, (*darwinDir)(unsafe.Pointer(dir)).h)
  1835. return de
  1836. }
  1837. func Xclosedir(t *TLS, dir uintptr) int32 {
  1838. if __ccgo_strace {
  1839. trc("t=%v dir=%v, (%v:)", t, dir, origin(2))
  1840. }
  1841. // trc("---- closedir: %#x", dir)
  1842. r := Xclose(t, int32((*darwinDir)(unsafe.Pointer(dir)).fd))
  1843. Xfree(t, dir)
  1844. return r
  1845. }
  1846. // int pipe(int pipefd[2]);
  1847. func Xpipe(t *TLS, pipefd uintptr) int32 {
  1848. if __ccgo_strace {
  1849. trc("t=%v pipefd=%v, (%v:)", t, pipefd, origin(2))
  1850. }
  1851. var a [2]int
  1852. if err := unix.Pipe(a[:]); err != nil {
  1853. if dmesgs {
  1854. dmesg("%v: %v FAIL", origin(1), err)
  1855. }
  1856. t.setErrno(err)
  1857. return -1
  1858. }
  1859. *(*[2]int32)(unsafe.Pointer(pipefd)) = [2]int32{int32(a[0]), int32(a[1])}
  1860. if dmesgs {
  1861. dmesg("%v: %v ok", origin(1), a)
  1862. }
  1863. return 0
  1864. }
  1865. // int __isoc99_sscanf(const char *str, const char *format, ...);
  1866. func X__isoc99_sscanf(t *TLS, str, format, va uintptr) int32 {
  1867. if __ccgo_strace {
  1868. trc("t=%v va=%v, (%v:)", t, va, origin(2))
  1869. }
  1870. r := scanf(strings.NewReader(GoString(str)), format, va)
  1871. // if dmesgs {
  1872. // dmesg("%v: %q %q: %d", origin(1), GoString(str), GoString(format), r)
  1873. // }
  1874. return r
  1875. }
  1876. // int sscanf(const char *str, const char *format, ...);
  1877. func Xsscanf(t *TLS, str, format, va uintptr) int32 {
  1878. if __ccgo_strace {
  1879. trc("t=%v va=%v, (%v:)", t, va, origin(2))
  1880. }
  1881. r := scanf(strings.NewReader(GoString(str)), format, va)
  1882. // if dmesgs {
  1883. // dmesg("%v: %q %q: %d", origin(1), GoString(str), GoString(format), r)
  1884. // }
  1885. return r
  1886. }
  1887. // int posix_fadvise(int fd, off_t offset, off_t len, int advice);
  1888. func Xposix_fadvise(t *TLS, fd int32, offset, len types.Off_t, advice int32) int32 {
  1889. if __ccgo_strace {
  1890. trc("t=%v fd=%v len=%v advice=%v, (%v:)", t, fd, len, advice, origin(2))
  1891. }
  1892. panic(todo(""))
  1893. }
  1894. // clock_t clock(void);
  1895. func Xclock(t *TLS) time.Clock_t {
  1896. if __ccgo_strace {
  1897. trc("t=%v, (%v:)", t, origin(2))
  1898. }
  1899. return time.Clock_t(gotime.Since(startTime) * gotime.Duration(time.CLOCKS_PER_SEC) / gotime.Second)
  1900. }
  1901. // int iswspace(wint_t wc);
  1902. func Xiswspace(t *TLS, wc wctype.Wint_t) int32 {
  1903. if __ccgo_strace {
  1904. trc("t=%v wc=%v, (%v:)", t, wc, origin(2))
  1905. }
  1906. return Bool32(unicode.IsSpace(rune(wc)))
  1907. }
  1908. // int iswalnum(wint_t wc);
  1909. func Xiswalnum(t *TLS, wc wctype.Wint_t) int32 {
  1910. if __ccgo_strace {
  1911. trc("t=%v wc=%v, (%v:)", t, wc, origin(2))
  1912. }
  1913. return Bool32(unicode.IsLetter(rune(wc)) || unicode.IsNumber(rune(wc)))
  1914. }
  1915. // void arc4random_buf(void *buf, size_t nbytes);
  1916. func Xarc4random_buf(t *TLS, buf uintptr, buflen size_t) {
  1917. if __ccgo_strace {
  1918. trc("t=%v buf=%v buflen=%v, (%v:)", t, buf, buflen, origin(2))
  1919. }
  1920. if _, err := crand.Read((*RawMem)(unsafe.Pointer(buf))[:buflen]); err != nil {
  1921. panic(todo(""))
  1922. }
  1923. }
  1924. type darwin_mutexattr_t struct {
  1925. sig int64
  1926. x [8]byte
  1927. }
  1928. type darwin_mutex_t struct {
  1929. sig int64
  1930. x [65]byte
  1931. }
  1932. func X__ccgo_pthreadMutexattrGettype(tls *TLS, a uintptr) int32 {
  1933. if __ccgo_strace {
  1934. trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
  1935. }
  1936. return (int32((*darwin_mutexattr_t)(unsafe.Pointer(a)).x[4] >> 2 & 3))
  1937. }
  1938. func X__ccgo_getMutexType(tls *TLS, m uintptr) int32 {
  1939. if __ccgo_strace {
  1940. trc("tls=%v m=%v, (%v:)", tls, m, origin(2))
  1941. }
  1942. return (int32((*darwin_mutex_t)(unsafe.Pointer(m)).x[4] >> 2 & 3))
  1943. }
  1944. func X__ccgo_pthreadAttrGetDetachState(tls *TLS, a uintptr) int32 {
  1945. if __ccgo_strace {
  1946. trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
  1947. }
  1948. return (*pthreadAttr)(unsafe.Pointer(a)).detachState
  1949. }
  1950. func Xpthread_attr_getdetachstate(tls *TLS, a uintptr, state uintptr) int32 {
  1951. if __ccgo_strace {
  1952. trc("tls=%v a=%v state=%v, (%v:)", tls, a, state, origin(2))
  1953. }
  1954. panic(todo(""))
  1955. }
  1956. func Xpthread_attr_setdetachstate(tls *TLS, a uintptr, state int32) (r int32) {
  1957. if uint32(state) > 1 {
  1958. return errno.EINVAL
  1959. }
  1960. (*pthreadAttr)(unsafe.Pointer(a)).detachState = state
  1961. return 0
  1962. }
  1963. func Xpthread_mutexattr_destroy(tls *TLS, a uintptr) int32 {
  1964. if __ccgo_strace {
  1965. trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
  1966. }
  1967. return 0
  1968. }
  1969. func Xpthread_mutexattr_init(tls *TLS, a uintptr) int32 {
  1970. if __ccgo_strace {
  1971. trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
  1972. }
  1973. *(*darwin_mutexattr_t)(unsafe.Pointer(a)) = darwin_mutexattr_t{}
  1974. return 0
  1975. }
  1976. func Xpthread_mutexattr_settype(tls *TLS, a uintptr, type1 int32) int32 {
  1977. if __ccgo_strace {
  1978. trc("tls=%v a=%v type1=%v, (%v:)", tls, a, type1, origin(2))
  1979. }
  1980. if uint32(type1) > uint32(2) {
  1981. return errno.EINVAL
  1982. }
  1983. (*darwin_mutexattr_t)(unsafe.Pointer(a)).x[4] = byte(type1 << 2)
  1984. return 0
  1985. }
  1986. // ssize_t writev(int fd, const struct iovec *iov, int iovcnt);
  1987. func Xwritev(t *TLS, fd int32, iov uintptr, iovcnt int32) types.Ssize_t {
  1988. if __ccgo_strace {
  1989. trc("t=%v fd=%v iov=%v iovcnt=%v, (%v:)", t, fd, iov, iovcnt, origin(2))
  1990. }
  1991. // if dmesgs {
  1992. // dmesg("%v: fd %v iov %#x iovcnt %v", origin(1), fd, iov, iovcnt)
  1993. // }
  1994. r, _, err := unix.Syscall(unix.SYS_WRITEV, uintptr(fd), iov, uintptr(iovcnt))
  1995. if err != 0 {
  1996. if dmesgs {
  1997. dmesg("%v: %v FAIL", origin(1), err)
  1998. }
  1999. t.setErrno(err)
  2000. return -1
  2001. }
  2002. return types.Ssize_t(r)
  2003. }
  2004. // int pause(void);
  2005. func Xpause(t *TLS) int32 {
  2006. if __ccgo_strace {
  2007. trc("t=%v, (%v:)", t, origin(2))
  2008. }
  2009. c := make(chan os.Signal)
  2010. gosignal.Notify(c,
  2011. unix.SIGABRT,
  2012. unix.SIGALRM,
  2013. unix.SIGBUS,
  2014. unix.SIGCHLD,
  2015. unix.SIGCONT,
  2016. unix.SIGFPE,
  2017. unix.SIGHUP,
  2018. unix.SIGILL,
  2019. // unix.SIGINT,
  2020. unix.SIGIO,
  2021. unix.SIGIOT,
  2022. unix.SIGKILL,
  2023. unix.SIGPIPE,
  2024. unix.SIGPROF,
  2025. unix.SIGQUIT,
  2026. unix.SIGSEGV,
  2027. unix.SIGSTOP,
  2028. unix.SIGSYS,
  2029. unix.SIGTERM,
  2030. unix.SIGTRAP,
  2031. unix.SIGTSTP,
  2032. unix.SIGTTIN,
  2033. unix.SIGTTOU,
  2034. unix.SIGURG,
  2035. unix.SIGUSR1,
  2036. unix.SIGUSR2,
  2037. unix.SIGVTALRM,
  2038. unix.SIGWINCH,
  2039. unix.SIGXCPU,
  2040. unix.SIGXFSZ,
  2041. )
  2042. switch <-c {
  2043. case unix.SIGINT:
  2044. panic(todo(""))
  2045. default:
  2046. t.setErrno(errno.EINTR)
  2047. return -1
  2048. }
  2049. }
  2050. // #define __DARWIN_FD_SETSIZE 1024
  2051. // #define __DARWIN_NFDBITS (sizeof(__int32_t) * __DARWIN_NBBY) /* bits per mask */
  2052. // #define __DARWIN_NBBY 8 /* bits in a byte */
  2053. // #define __DARWIN_howmany(x, y) ((((x) % (y)) == 0) ? ((x) / (y)) : (((x) / (y)) + 1)) /* # y's == x bits? */
  2054. // typedef struct fd_set {
  2055. // __int32_t fds_bits[__DARWIN_howmany(__DARWIN_FD_SETSIZE, __DARWIN_NFDBITS)];
  2056. // } fd_set;
  2057. // __darwin_fd_set(int _fd, struct fd_set *const _p)
  2058. //
  2059. // {
  2060. // (_p->fds_bits[(unsigned long)_fd / __DARWIN_NFDBITS] |= ((__int32_t)(((unsigned long)1) << ((unsigned long)_fd % __DARWIN_NFDBITS))));
  2061. // }
  2062. func X__darwin_fd_set(tls *TLS, _fd int32, _p uintptr) int32 { /* main.c:12:1: */
  2063. if __ccgo_strace {
  2064. trc("tls=%v _fd=%v _p=%v, (%v:)", tls, _fd, _p, origin(2))
  2065. }
  2066. *(*int32)(unsafe.Pointer(_p + uintptr(uint64(_fd)/(uint64(unsafe.Sizeof(int32(0)))*uint64(8)))*4)) |= int32(uint64(uint64(1)) << (uint64(_fd) % (uint64(unsafe.Sizeof(int32(0))) * uint64(8))))
  2067. return int32(0)
  2068. }
  2069. // __darwin_fd_isset(int _fd, const struct fd_set *_p)
  2070. //
  2071. // {
  2072. // return _p->fds_bits[(unsigned long)_fd / __DARWIN_NFDBITS] & ((__int32_t)(((unsigned long)1) << ((unsigned long)_fd % __DARWIN_NFDBITS)));
  2073. // }
  2074. func X__darwin_fd_isset(tls *TLS, _fd int32, _p uintptr) int32 { /* main.c:17:1: */
  2075. if __ccgo_strace {
  2076. trc("tls=%v _fd=%v _p=%v, (%v:)", tls, _fd, _p, origin(2))
  2077. }
  2078. return *(*int32)(unsafe.Pointer(_p + uintptr(uint64(_fd)/(uint64(unsafe.Sizeof(int32(0)))*uint64(8)))*4)) & int32(uint64(uint64(1))<<(uint64(_fd)%(uint64(unsafe.Sizeof(int32(0)))*uint64(8))))
  2079. }
  2080. // __darwin_fd_clr(int _fd, struct fd_set *const _p)
  2081. //
  2082. // {
  2083. // (_p->fds_bits[(unsigned long)_fd / __DARWIN_NFDBITS] &= ~((__int32_t)(((unsigned long)1) << ((unsigned long)_fd % __DARWIN_NFDBITS))));
  2084. // }
  2085. func X__darwin_fd_clr(tls *TLS, _fd int32, _p uintptr) int32 { /* main.c:22:1: */
  2086. if __ccgo_strace {
  2087. trc("tls=%v _fd=%v _p=%v, (%v:)", tls, _fd, _p, origin(2))
  2088. }
  2089. *(*int32)(unsafe.Pointer(_p + uintptr(uint64(_fd)/(uint64(unsafe.Sizeof(int32(0)))*uint64(8)))*4)) &= ^int32(uint64(uint64(1)) << (uint64(_fd) % (uint64(unsafe.Sizeof(int32(0))) * uint64(8))))
  2090. return int32(0)
  2091. }
  2092. // int ungetc(int c, FILE *stream);
  2093. func Xungetc(t *TLS, c int32, stream uintptr) int32 {
  2094. if __ccgo_strace {
  2095. trc("t=%v c=%v stream=%v, (%v:)", t, c, stream, origin(2))
  2096. }
  2097. panic(todo(""))
  2098. }
  2099. // int issetugid(void);
  2100. func Xissetugid(t *TLS) int32 {
  2101. if __ccgo_strace {
  2102. trc("t=%v, (%v:)", t, origin(2))
  2103. }
  2104. panic(todo(""))
  2105. }
  2106. var progname uintptr
  2107. // const char *getprogname(void);
  2108. func Xgetprogname(t *TLS) uintptr {
  2109. if __ccgo_strace {
  2110. trc("t=%v, (%v:)", t, origin(2))
  2111. }
  2112. if progname != 0 {
  2113. return progname
  2114. }
  2115. var err error
  2116. progname, err = CString(filepath.Base(os.Args[0]))
  2117. if err != nil {
  2118. t.setErrno(err)
  2119. return 0
  2120. }
  2121. return progname
  2122. }
  2123. // void uuid_copy(uuid_t dst, uuid_t src);
  2124. func Xuuid_copy(t *TLS, dst, src uintptr) {
  2125. if __ccgo_strace {
  2126. trc("t=%v src=%v, (%v:)", t, src, origin(2))
  2127. }
  2128. *(*uuid.Uuid_t)(unsafe.Pointer(dst)) = *(*uuid.Uuid_t)(unsafe.Pointer(src))
  2129. }
  2130. // int uuid_parse( char *in, uuid_t uu);
  2131. func Xuuid_parse(t *TLS, in uintptr, uu uintptr) int32 {
  2132. if __ccgo_strace {
  2133. trc("t=%v in=%v uu=%v, (%v:)", t, in, uu, origin(2))
  2134. }
  2135. r, err := guuid.Parse(GoString(in))
  2136. if err != nil {
  2137. return -1
  2138. }
  2139. copy((*RawMem)(unsafe.Pointer(uu))[:unsafe.Sizeof(uuid.Uuid_t{})], r[:])
  2140. return 0
  2141. }
  2142. // struct __float2 { float __sinval; float __cosval; };
  2143. // struct __float2 __sincosf_stret(float);
  2144. func X__sincosf_stret(t *TLS, f float32) struct{ F__sinval, F__cosval float32 } {
  2145. panic(todo(""))
  2146. }
  2147. // struct __double2 { double __sinval; double __cosval; };
  2148. // struct __double2 __sincos_stret(double);
  2149. func X__sincos_stret(t *TLS, f float64) struct{ F__sinval, F__cosval float64 } {
  2150. panic(todo(""))
  2151. }
  2152. // struct __float2 __sincospif_stret(float);
  2153. func X__sincospif_stret(t *TLS, f float32) struct{ F__sinval, F__cosval float32 } {
  2154. panic(todo(""))
  2155. }
  2156. // struct _double2 __sincospi_stret(double);
  2157. func X__sincospi_stret(t *TLS, f float64) struct{ F__sinval, F__cosval float64 } {
  2158. panic(todo(""))
  2159. }
  2160. // int __srget(FILE *);
  2161. func X__srget(t *TLS, f uintptr) int32 {
  2162. if __ccgo_strace {
  2163. trc("t=%v f=%v, (%v:)", t, f, origin(2))
  2164. }
  2165. panic(todo(""))
  2166. }
  2167. // int __svfscanf(FILE *, const char *, va_list) __scanflike(2, 0);
  2168. func X__svfscanf(t *TLS, f uintptr, p, q uintptr) int32 {
  2169. if __ccgo_strace {
  2170. trc("t=%v f=%v q=%v, (%v:)", t, f, q, origin(2))
  2171. }
  2172. panic(todo(""))
  2173. }
  2174. // int __swbuf(int, FILE *);
  2175. func X__swbuf(t *TLS, i int32, f uintptr) int32 {
  2176. if __ccgo_strace {
  2177. trc("t=%v i=%v f=%v, (%v:)", t, i, f, origin(2))
  2178. }
  2179. panic(todo(""))
  2180. }
  2181. // int nanosleep(const struct timespec *req, struct timespec *rem);
  2182. func Xnanosleep(t *TLS, req, rem uintptr) int32 {
  2183. if __ccgo_strace {
  2184. trc("t=%v rem=%v, (%v:)", t, rem, origin(2))
  2185. }
  2186. v := *(*time.Timespec)(unsafe.Pointer(req))
  2187. gotime.Sleep(gotime.Second*gotime.Duration(v.Ftv_sec) + gotime.Duration(v.Ftv_nsec))
  2188. return 0
  2189. }
  2190. // // void malloc_set_zone_name(malloc_zone_t *zone, const char *name)
  2191. // func Xmalloc_set_zone_name(t *TLS, zone, name uintptr) {
  2192. // if __ccgo_strace {
  2193. // trc("t=%v zone=%v name=%v, (%v:)", t, zone, name, origin(2))
  2194. // }
  2195. // // nop
  2196. // }
  2197. // size_t malloc_size(const void *ptr);
  2198. func Xmalloc_size(t *TLS, p uintptr) (r types.Size_t) {
  2199. if __ccgo_strace {
  2200. trc("t=%v p=%v, (%v:)", t, p, origin(2))
  2201. defer func() { trc("-> %v", r) }()
  2202. }
  2203. if p == 0 {
  2204. return 0
  2205. }
  2206. allocMu.Lock()
  2207. defer allocMu.Unlock()
  2208. return types.Size_t(memory.UintptrUsableSize(p))
  2209. }
  2210. // int open(const char *pathname, int flags, ...);
  2211. func Xopen64(t *TLS, pathname uintptr, flags int32, args uintptr) int32 {
  2212. if __ccgo_strace {
  2213. trc("t=%v pathname=%v flags=%v args=%v, (%v:)", t, pathname, flags, args, origin(2))
  2214. }
  2215. var mode types.Mode_t
  2216. if args != 0 {
  2217. mode = (types.Mode_t)(VaUint32(&args))
  2218. }
  2219. fdcwd := fcntl.AT_FDCWD
  2220. n, _, err := unix.Syscall6(unix.SYS_OPENAT, uintptr(fdcwd), pathname, uintptr(flags), uintptr(mode), 0, 0)
  2221. if err != 0 {
  2222. // if dmesgs {
  2223. // dmesg("%v: %q %#x: %v", origin(1), GoString(pathname), flags, err)
  2224. // }
  2225. t.setErrno(err)
  2226. return -1
  2227. }
  2228. // if dmesgs {
  2229. // dmesg("%v: %q flags %#x mode %#o: fd %v", origin(1), GoString(pathname), flags, mode, n)
  2230. // }
  2231. return int32(n)
  2232. }
  2233. // int getrlimit(int resource, struct rlimit *rlim);
  2234. func Xgetrlimit(t *TLS, resource int32, rlim uintptr) int32 {
  2235. if __ccgo_strace {
  2236. trc("t=%v resource=%v rlim=%v, (%v:)", t, resource, rlim, origin(2))
  2237. }
  2238. if _, _, err := unix.Syscall(unix.SYS_GETRLIMIT, uintptr(resource), uintptr(rlim), 0); err != 0 {
  2239. t.setErrno(err)
  2240. return -1
  2241. }
  2242. return 0
  2243. }
  2244. // int setrlimit(int resource, const struct rlimit *rlim);
  2245. func Xsetrlimit(t *TLS, resource int32, rlim uintptr) int32 {
  2246. if __ccgo_strace {
  2247. trc("t=%v resource=%v rlim=%v, (%v:)", t, resource, rlim, origin(2))
  2248. }
  2249. if _, _, err := unix.Syscall(unix.SYS_SETRLIMIT, uintptr(resource), uintptr(rlim), 0); err != 0 {
  2250. t.setErrno(err)
  2251. return -1
  2252. }
  2253. return 0
  2254. }
  2255. func X__fpclassifyd(tls *TLS, x float64) (r int32) {
  2256. return X__fpclassify(tls, x)
  2257. }
  2258. var Xin6addr_any = in6_addr{}
  2259. func X__builtin_lround(tls *TLS, x float64) (r long) {
  2260. return Xlround(tls, x)
  2261. }
  2262. func Xlround(tls *TLS, x float64) (r long) {
  2263. return long(Xround(tls, x))
  2264. }
  2265. // https://g.co/gemini/share/2c37d5b57994
  2266. // Constants mirroring C's ftw type flags
  2267. const (
  2268. FTW_F = 0 // Regular file
  2269. FTW_D = 1 // Directory (visited pre-order)
  2270. FTW_DNR = 2 // Directory that cannot be read
  2271. FTW_NS = 4 // Stat failed (permissions, broken link, etc.)
  2272. FTW_SL = 4 // Symbolic link (lstat was used)
  2273. // Note: C's ftw might have other flags like FTW_DP (post-order dir) or FTW_SLN
  2274. // which are not directly supported by filepath.WalkDir's simple pre-order traversal.
  2275. // This emulation focuses on the most common flags associated with stat/lstat results.
  2276. )
  2277. // ftwStopError is used internally to signal that the walk should stop
  2278. // because the user callback returned a non-zero value.
  2279. type ftwStopError struct {
  2280. stopValue int
  2281. }
  2282. func (e *ftwStopError) Error() string {
  2283. return fmt.Sprintf("ftw walk stopped by callback with return value %d", e.stopValue)
  2284. }
  2285. // goFtwFunc is the callback function type, mirroring the C ftw callback.
  2286. // It receives the path, file info (if available), and a type flag.
  2287. // Returning a non-zero value stops the walk and becomes the return value of Ftw.
  2288. // Returning 0 continues the walk.
  2289. type goFtwFunc func(path string, info os.FileInfo, typeflag int) int
  2290. // Ftw emulates the C standard library function ftw(3).
  2291. // It walks the directory tree starting at 'dirpath' and calls the 'callback'
  2292. // function for each entry encountered.
  2293. //
  2294. // Parameters:
  2295. // - dirpath: The root directory path for the traversal.
  2296. // - callback: The goFtwFunc to call for each file system entry.
  2297. // - nopenfd: This parameter is part of the C ftw signature but is IGNORED
  2298. // in this Go implementation. Go's filepath.WalkDir manages concurrency
  2299. // and file descriptors internally.
  2300. //
  2301. // Returns:
  2302. // - 0 on successful completion of the walk.
  2303. // - The non-zero value returned by the callback, if the callback terminated the walk.
  2304. // - -1 if an error occurred during the walk that wasn't handled by calling
  2305. // the callback with FTW_DNR or FTW_NS (e.g., error accessing the initial dirpath).
  2306. func ftw(dirpath string, callback goFtwFunc, nopenfd int) int {
  2307. // nopenfd is ignored in this Go implementation.
  2308. walkErr := filepath.WalkDir(dirpath, func(path string, d fs.DirEntry, err error) error {
  2309. var info os.FileInfo
  2310. var typeflag int
  2311. // --- Handle errors passed by WalkDir ---
  2312. if err != nil {
  2313. // Check if the error is related to accessing a directory
  2314. if errors.Is(err, fs.ErrPermission) || errors.Is(err, unix.EACCES) { // Added syscall.EACCES check
  2315. // Try to determine if it's a directory we can't read
  2316. // We might not have 'd' if the error occurred trying to list 'path' contents
  2317. // Let's try a direct Lstat on the path itself if d is nil
  2318. lstatInfo, lstatErr := os.Lstat(path)
  2319. if lstatErr == nil && lstatInfo.IsDir() {
  2320. typeflag = FTW_DNR // Directory, but WalkDir errored (likely reading it)
  2321. info = lstatInfo // Provide the info we could get
  2322. } else {
  2323. // Can't confirm it's a directory, or Lstat itself failed
  2324. typeflag = FTW_NS // Treat as general stat failure
  2325. // info remains nil
  2326. }
  2327. } else {
  2328. // Other errors (e.g., broken symlink during traversal, I/O error)
  2329. typeflag = FTW_NS
  2330. // Attempt to get Lstat info even if WalkDir had an error, maybe it's available
  2331. lstatInfo, _ := os.Lstat(path) // Ignore error here, if it fails info stays nil
  2332. info = lstatInfo
  2333. }
  2334. // Even with errors, call the callback with the path and appropriate flag
  2335. stopVal := callback(path, info, typeflag)
  2336. if stopVal != 0 {
  2337. return &ftwStopError{stopValue: stopVal}
  2338. }
  2339. // If the error was on a directory, returning the error might stop WalkDir
  2340. // from descending. If it was fs.ErrPermission on a dir, WalkDir might
  2341. // pass filepath.SkipDir implicitly or continue depending on implementation.
  2342. // Let's return nil here to *try* to continue the walk for other siblings
  2343. // if the callback didn't stop it. The callback *was* notified.
  2344. // If the error prevents further progress WalkDir will stop anyway.
  2345. return nil // Allow walk to potentially continue elsewhere
  2346. }
  2347. // --- No error from WalkDir, process the DirEntry ---
  2348. info, err = d.Info() // Get FileInfo (like C's stat/lstat result)
  2349. if err != nil {
  2350. // Error getting info for an entry WalkDir *could* list (rare, maybe permissions changed?)
  2351. typeflag = FTW_NS
  2352. // info remains nil
  2353. } else {
  2354. // Determine type flag based on file mode
  2355. mode := info.Mode()
  2356. if mode&fs.ModeSymlink != 0 {
  2357. typeflag = FTW_SL
  2358. } else if mode.IsDir() {
  2359. typeflag = FTW_D // Visited pre-order
  2360. } else if mode.IsRegular() {
  2361. typeflag = FTW_F
  2362. } else {
  2363. // Other types (device, socket, pipe, etc.) - C ftw usually lumps these under FTW_F
  2364. // or might have FTW_NS if stat fails. Let's treat non-dir, non-link, non-regular
  2365. // as FTW_F for simplicity, aligning with common C practice, or FTW_NS if stat failed above.
  2366. // Since we have info here, we know stat didn't fail.
  2367. // Let's be more specific, maybe treat others as FTW_NS? Or stick to FTW_F?
  2368. // C ftw man page isn't super specific about all types. FTW_F seems reasonable.
  2369. typeflag = FTW_F // Treat other valid types as 'files' for simplicity
  2370. }
  2371. }
  2372. // --- Call the user callback ---
  2373. stopVal := callback(path, info, typeflag)
  2374. if stopVal != 0 {
  2375. // User wants to stop the walk
  2376. return &ftwStopError{stopValue: stopVal}
  2377. }
  2378. return nil // Continue walk
  2379. })
  2380. // --- Handle WalkDir's final return value ---
  2381. if walkErr == nil {
  2382. return 0 // Success
  2383. }
  2384. // Check if the error was our custom stop signal
  2385. var stopErr *ftwStopError
  2386. if errors.As(walkErr, &stopErr) {
  2387. return stopErr.stopValue // Return the value from the callback
  2388. }
  2389. // Otherwise, it was an unhandled error during the walk
  2390. // (e.g., initial dirpath access error, or other error not mapped to FTW_NS/DNR)
  2391. return -1 // General error return
  2392. }
  2393. func Xftw(tls *TLS, path uintptr, fn uintptr, fd_limit int32) (r int32) {
  2394. statp := tls.Alloc(int(unsafe.Sizeof(unix.Stat_t{})))
  2395. defer tls.Free(int(unsafe.Sizeof(unix.Stat_t{})))
  2396. return int32(ftw(
  2397. GoString(path),
  2398. func(path string, info os.FileInfo, typeflag int) int {
  2399. cs, _ := CString(path)
  2400. defer Xfree(tls, cs)
  2401. Xstat(tls, cs, statp)
  2402. return int((*(*func(*TLS, uintptr, uintptr, int32) int32)(unsafe.Pointer(&struct{ uintptr }{fn})))(tls, cs, statp, int32(typeflag)))
  2403. },
  2404. int(fd_limit),
  2405. ))
  2406. }
  2407. func Xexecve(tls *TLS, path uintptr, argv uintptr, envp uintptr) (r int32) {
  2408. goPath := GoString(path)
  2409. var goArgv, goEnvp []string
  2410. for p := *(*uintptr)(unsafe.Pointer(argv)); p != 0; p = *(*uintptr)(unsafe.Pointer(argv)) {
  2411. goArgv = append(goArgv, GoString(p))
  2412. argv += unsafe.Sizeof(uintptr(0))
  2413. }
  2414. for p := *(*uintptr)(unsafe.Pointer(envp)); p != 0; p = *(*uintptr)(unsafe.Pointer(envp)) {
  2415. goEnvp = append(goEnvp, GoString(p))
  2416. envp += unsafe.Sizeof(uintptr(0))
  2417. }
  2418. if err := unix.Exec(goPath, goArgv, goEnvp); err != nil {
  2419. tls.setErrno(err)
  2420. return -1
  2421. }
  2422. panic("unreachable")
  2423. }
  2424. func Xsetuid(tls *TLS, uid uint32) (r int32) {
  2425. if __ccgo_strace {
  2426. trc("tls=%v uid=%v, (%v:)", tls, uid, origin(2))
  2427. defer func() { trc("-> %v", r) }()
  2428. }
  2429. if err := unix.Setuid(int(uid)); err != nil {
  2430. tls.setErrno(err)
  2431. return -1
  2432. }
  2433. return 0
  2434. }
  2435. func Xsetgid(tls *TLS, gid uint32) (r int32) {
  2436. if __ccgo_strace {
  2437. trc("tls=%v gid=%v, (%v:)", tls, gid, origin(2))
  2438. defer func() { trc("-> %v", r) }()
  2439. }
  2440. if err := unix.Setgid(int(gid)); err != nil {
  2441. tls.setErrno(err)
  2442. return -1
  2443. }
  2444. return 0
  2445. }
  2446. func Xdup(tls *TLS, fd int32) (r int32) {
  2447. if __ccgo_strace {
  2448. trc("tls=%v fd=%v, (%v:)", tls, fd, origin(2))
  2449. defer func() { trc("-> %v", r) }()
  2450. }
  2451. nfd, err := unix.Dup(int(fd))
  2452. if err != nil {
  2453. tls.setErrno(err)
  2454. return -1
  2455. }
  2456. return int32(nfd)
  2457. }
  2458. func X__builtin_ctz(t *TLS, n uint32) int32 {
  2459. return int32(mbits.TrailingZeros32(n))
  2460. }