libc_openbsd.go 74 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862
  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. "encoding/hex"
  7. "fmt"
  8. "io"
  9. "os"
  10. "os/exec"
  11. "path/filepath"
  12. "runtime"
  13. "runtime/debug"
  14. "strings"
  15. gotime "time"
  16. "unsafe"
  17. guuid "github.com/google/uuid"
  18. "golang.org/x/sys/unix"
  19. "modernc.org/libc/errno"
  20. "modernc.org/libc/fcntl"
  21. "modernc.org/libc/fts"
  22. gonetdb "modernc.org/libc/honnef.co/go/netdb"
  23. "modernc.org/libc/langinfo"
  24. "modernc.org/libc/limits"
  25. "modernc.org/libc/netdb"
  26. "modernc.org/libc/netinet/in"
  27. "modernc.org/libc/stdio"
  28. "modernc.org/libc/sys/socket"
  29. "modernc.org/libc/sys/stat"
  30. "modernc.org/libc/sys/types"
  31. "modernc.org/libc/termios"
  32. "modernc.org/libc/time"
  33. "modernc.org/libc/unistd"
  34. "modernc.org/libc/utime"
  35. "modernc.org/libc/uuid"
  36. )
  37. var (
  38. startTime = gotime.Now() // For clock(3)
  39. in6_addr_any in.In6_addr
  40. )
  41. type Tsize_t = types.Size_t
  42. type syscallErrno = unix.Errno
  43. // // Keep these outside of the var block otherwise go generate will miss them.
  44. var X__stderrp = Xstdout
  45. var X__stdinp = Xstdin
  46. var X__stdoutp = Xstdout
  47. var X__sF [3]stdio.FILE
  48. var X_tolower_tab_ uintptr
  49. var X_toupper_tab_ uintptr
  50. func init() {
  51. // fake a TLS since this comes before NewTLS() or Start()
  52. t := &TLS{errnop: uintptr(unsafe.Pointer(&errno0))}
  53. X_tolower_tab_ = Xmalloc(t, 2*65537)
  54. if X_tolower_tab_ == 0 {
  55. panic("unable to allocate tolower table")
  56. }
  57. X_toupper_tab_ = Xmalloc(t, 2*65537)
  58. if X_tolower_tab_ == 0 {
  59. panic("unable to allocate toupper table")
  60. }
  61. for c := rune(0); c < 0xffff; c++ {
  62. y := c
  63. s := strings.ToLower(string(c))
  64. a := []rune(s)
  65. if len(a) != 0 {
  66. y = a[0]
  67. }
  68. (*[65536]uint16)(unsafe.Pointer(X_tolower_tab_))[c+1] = uint16(y)
  69. y = c
  70. s = strings.ToUpper(string(c))
  71. a = []rune(s)
  72. if len(a) != 0 {
  73. y = a[0]
  74. }
  75. (*[65536]uint16)(unsafe.Pointer(X_toupper_tab_))[c+1] = uint16(y)
  76. }
  77. }
  78. // include/stdio.h:486:extern int __isthreaded;
  79. var X__isthreaded int32
  80. // lib/libc/locale/mblocal.h:62: int __mb_sb_limit;
  81. var X__mb_sb_limit int32 = 128 // UTF-8
  82. // include/runetype.h:94:extern _Thread_local const _RuneLocale *_ThreadRuneLocale;
  83. var X_ThreadRuneLocale uintptr //TODO initialize and implement _Thread_local semantics.
  84. // include/xlocale/_ctype.h:54:_RuneLocale *__runes_for_locale(locale_t, int*);
  85. func X__runes_for_locale(t *TLS, l locale_t, p uintptr) uintptr {
  86. if __ccgo_strace {
  87. trc("t=%v l=%v p=%v, (%v:)", t, l, p, origin(2))
  88. }
  89. panic(todo(""))
  90. }
  91. type file uintptr
  92. func (f file) fd() int32 { return int32((*stdio.FILE)(unsafe.Pointer(f)).F_file) }
  93. func (f file) setFd(fd int32) { (*stdio.FILE)(unsafe.Pointer(f)).F_file = int16(fd) }
  94. func (f file) err() bool {
  95. return (*stdio.FILE)(unsafe.Pointer(f)).F_flags&1 != 0
  96. }
  97. func (f file) setErr() {
  98. (*stdio.FILE)(unsafe.Pointer(f)).F_flags |= 1
  99. }
  100. func (f file) close(t *TLS) int32 {
  101. fd := f.fd()
  102. r := Xclose(t, fd)
  103. switch fd {
  104. case unistd.STDIN_FILENO, unistd.STDOUT_FILENO, unistd.STDERR_FILENO:
  105. X__sF[fd] = stdio.FILE{}
  106. default:
  107. Xfree(t, uintptr(f))
  108. }
  109. if r < 0 {
  110. return stdio.EOF
  111. }
  112. return 0
  113. }
  114. func newFile(t *TLS, fd int32) uintptr {
  115. var p uintptr
  116. switch fd {
  117. case unistd.STDIN_FILENO:
  118. p = uintptr(unsafe.Pointer(&X__sF[0]))
  119. case unistd.STDOUT_FILENO:
  120. p = uintptr(unsafe.Pointer(&X__sF[1]))
  121. case unistd.STDERR_FILENO:
  122. p = uintptr(unsafe.Pointer(&X__sF[2]))
  123. default:
  124. if p = Xcalloc(t, 1, types.Size_t(unsafe.Sizeof(stdio.FILE{}))); p == 0 {
  125. return 0
  126. }
  127. }
  128. file(p).setFd(fd)
  129. return p
  130. }
  131. func fwrite(fd int32, b []byte) (int, error) {
  132. if fd == unistd.STDOUT_FILENO {
  133. return write(b)
  134. }
  135. // if dmesgs {
  136. // dmesg("%v: fd %v: %s", origin(1), fd, b)
  137. // }
  138. return unix.Write(int(fd), b) //TODO use Xwrite
  139. }
  140. // unsigned long ___runetype(__ct_rune_t) __pure;
  141. func X___runetype(t *TLS, x int32) ulong {
  142. if __ccgo_strace {
  143. trc("t=%v x=%v, (%v:)", t, x, origin(2))
  144. }
  145. panic(todo(""))
  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 uint32) 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 getrusage(int who, struct rusage *usage);
  164. func Xgetrusage(t *TLS, who int32, usage uintptr) int32 {
  165. if __ccgo_strace {
  166. trc("t=%v who=%v usage=%v, (%v:)", t, who, usage, origin(2))
  167. }
  168. ru := unix.Rusage{}
  169. if err := unix.Getrusage(int(who), &ru); err != nil {
  170. t.setErrno(err)
  171. return -1
  172. }
  173. *(*unix.Rusage)(unsafe.Pointer(usage)) = ru
  174. return 0
  175. }
  176. // int fgetc(FILE *stream);
  177. func Xfgetc(t *TLS, stream uintptr) int32 {
  178. if __ccgo_strace {
  179. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  180. }
  181. fd := int((*stdio.FILE)(unsafe.Pointer(stream)).F_file)
  182. var buf [1]byte
  183. if n, _ := unix.Read(fd, buf[:]); n != 0 {
  184. return int32(buf[0])
  185. }
  186. return stdio.EOF
  187. }
  188. // int lstat(const char *pathname, struct stat *statbuf);
  189. func Xlstat(t *TLS, pathname, statbuf uintptr) int32 {
  190. if __ccgo_strace {
  191. trc("t=%v statbuf=%v, (%v:)", t, statbuf, origin(2))
  192. }
  193. return Xlstat64(t, pathname, statbuf)
  194. }
  195. // int stat(const char *pathname, struct stat *statbuf);
  196. func Xstat(t *TLS, pathname, statbuf uintptr) int32 {
  197. if __ccgo_strace {
  198. trc("t=%v statbuf=%v, (%v:)", t, statbuf, origin(2))
  199. }
  200. return Xstat64(t, pathname, statbuf)
  201. }
  202. // int chdir(const char *path);
  203. func Xchdir(t *TLS, path uintptr) int32 {
  204. if __ccgo_strace {
  205. trc("t=%v path=%v, (%v:)", t, path, origin(2))
  206. }
  207. if err := unix.Chdir(GoString(path)); err != nil {
  208. t.setErrno(err)
  209. return -1
  210. }
  211. if dmesgs {
  212. dmesg("%v: %q: ok", origin(1), GoString(path))
  213. }
  214. return 0
  215. }
  216. var localtime time.Tm
  217. // struct tm *localtime(const time_t *timep);
  218. func Xlocaltime(_ *TLS, timep uintptr) uintptr {
  219. loc := getLocalLocation()
  220. ut := *(*time.Time_t)(unsafe.Pointer(timep))
  221. t := gotime.Unix(int64(ut), 0).In(loc)
  222. localtime.Ftm_sec = int32(t.Second())
  223. localtime.Ftm_min = int32(t.Minute())
  224. localtime.Ftm_hour = int32(t.Hour())
  225. localtime.Ftm_mday = int32(t.Day())
  226. localtime.Ftm_mon = int32(t.Month() - 1)
  227. localtime.Ftm_year = int32(t.Year() - 1900)
  228. localtime.Ftm_wday = int32(t.Weekday())
  229. localtime.Ftm_yday = int32(t.YearDay())
  230. localtime.Ftm_isdst = Bool32(isTimeDST(t))
  231. return uintptr(unsafe.Pointer(&localtime))
  232. }
  233. // struct tm *localtime_r(const time_t *timep, struct tm *result);
  234. func Xlocaltime_r(_ *TLS, timep, result uintptr) uintptr {
  235. loc := getLocalLocation()
  236. ut := *(*time.Time_t)(unsafe.Pointer(timep))
  237. t := gotime.Unix(int64(ut), 0).In(loc)
  238. (*time.Tm)(unsafe.Pointer(result)).Ftm_sec = int32(t.Second())
  239. (*time.Tm)(unsafe.Pointer(result)).Ftm_min = int32(t.Minute())
  240. (*time.Tm)(unsafe.Pointer(result)).Ftm_hour = int32(t.Hour())
  241. (*time.Tm)(unsafe.Pointer(result)).Ftm_mday = int32(t.Day())
  242. (*time.Tm)(unsafe.Pointer(result)).Ftm_mon = int32(t.Month() - 1)
  243. (*time.Tm)(unsafe.Pointer(result)).Ftm_year = int32(t.Year() - 1900)
  244. (*time.Tm)(unsafe.Pointer(result)).Ftm_wday = int32(t.Weekday())
  245. (*time.Tm)(unsafe.Pointer(result)).Ftm_yday = int32(t.YearDay())
  246. (*time.Tm)(unsafe.Pointer(result)).Ftm_isdst = Bool32(isTimeDST(t))
  247. return result
  248. }
  249. // int open(const char *pathname, int flags, ...);
  250. func Xopen(t *TLS, pathname uintptr, flags int32, args uintptr) int32 {
  251. if __ccgo_strace {
  252. trc("t=%v pathname=%s flags=%v args=%v, (%v:)", t, GoString(pathname), flags, args, origin(2))
  253. }
  254. return Xopen64(t, pathname, flags, args)
  255. }
  256. // int open(const char *pathname, int flags, ...);
  257. func Xopen64(t *TLS, pathname uintptr, flags int32, args uintptr) int32 {
  258. if __ccgo_strace {
  259. trc("t=%v pathname=%s flags=%v args=%v, (%v:)", t, GoString(pathname), flags, args, origin(2))
  260. }
  261. var mode types.Mode_t
  262. if args != 0 {
  263. mode = (types.Mode_t)(VaUint32(&args))
  264. }
  265. fd, err := unix.Open(GoString(pathname), int(flags), mode)
  266. if err != nil {
  267. if __ccgo_strace {
  268. trc("%s: %s", err.Error(), GoString(pathname))
  269. }
  270. if dmesgs {
  271. dmesg("%v: %q %#x: %v", origin(1), GoString(pathname), flags, err)
  272. }
  273. t.setErrno(err)
  274. return -1
  275. }
  276. if dmesgs {
  277. dmesg("%v: %q flags %#x mode %#o: fd %v", origin(1), GoString(pathname), flags, mode, fd)
  278. }
  279. if __ccgo_strace {
  280. trc("%s fd=%d", GoString(pathname), fd)
  281. }
  282. return int32(fd)
  283. }
  284. // off_t lseek(int fd, off_t offset, int whence);
  285. func Xlseek(t *TLS, fd int32, offset types.Off_t, whence int32) types.Off_t {
  286. if __ccgo_strace {
  287. trc("t=%v fd=%v offset=%v whence=%v, (%v:)", t, fd, offset, whence, origin(2))
  288. }
  289. return types.Off_t(Xlseek64(t, fd, offset, whence))
  290. }
  291. var fsyncStatbuf stat.Stat
  292. // int fsync(int fd);
  293. func Xfsync(t *TLS, fd int32) int32 {
  294. if __ccgo_strace {
  295. trc("t=%v fd=%v, (%v:)", t, fd, origin(2))
  296. }
  297. if noFsync {
  298. // Simulate -DSQLITE_NO_SYNC for sqlite3 testfixture, see function full_sync in sqlite3.c
  299. return Xfstat(t, fd, uintptr(unsafe.Pointer(&fsyncStatbuf)))
  300. }
  301. if err := unix.Fsync(int(fd)); err != nil {
  302. t.setErrno(err)
  303. return -1
  304. }
  305. // if dmesgs {
  306. // dmesg("%v: %d: ok", origin(1), fd)
  307. // }
  308. return 0
  309. }
  310. // long sysconf(int name);
  311. func Xsysconf(t *TLS, name int32) long {
  312. if __ccgo_strace {
  313. trc("t=%v name=%v, (%v:)", t, name, origin(2))
  314. }
  315. switch name {
  316. case unistd.X_SC_PAGESIZE:
  317. return long(unix.Getpagesize())
  318. case unistd.X_SC_GETPW_R_SIZE_MAX:
  319. return -1
  320. case unistd.X_SC_GETGR_R_SIZE_MAX:
  321. return -1
  322. case unistd.X_SC_NPROCESSORS_ONLN:
  323. return long(runtime.NumCPU())
  324. }
  325. panic(todo("", name))
  326. }
  327. // int close(int fd);
  328. func Xclose(t *TLS, fd int32) int32 {
  329. if __ccgo_strace {
  330. trc("t=%v fd=%v, (%v:)", t, fd, origin(2))
  331. }
  332. if err := unix.Close(int(fd)); err != nil {
  333. t.setErrno(err)
  334. return -1
  335. }
  336. // if dmesgs {
  337. // dmesg("%v: %d: ok", origin(1), fd)
  338. // }
  339. return 0
  340. }
  341. // char *getcwd(char *buf, size_t size);
  342. func Xgetcwd(t *TLS, buf uintptr, size types.Size_t) uintptr {
  343. if __ccgo_strace {
  344. trc("t=%v buf=%v size=%v, (%v:)", t, buf, size, origin(2))
  345. }
  346. if _, err := unix.Getcwd((*RawMem)(unsafe.Pointer(buf))[:size:size]); err != nil {
  347. if dmesgs {
  348. dmesg("%v: %v FAIL", origin(1), err)
  349. }
  350. t.setErrno(err)
  351. return 0
  352. }
  353. if dmesgs {
  354. dmesg("%v: ok", origin(1))
  355. }
  356. return buf
  357. }
  358. // int fstat(int fd, struct stat *statbuf);
  359. func Xfstat(t *TLS, fd int32, statbuf uintptr) int32 {
  360. if __ccgo_strace {
  361. trc("t=%v fd=%v statbuf=%v, (%v:)", t, fd, statbuf, origin(2))
  362. }
  363. return Xfstat64(t, fd, statbuf)
  364. }
  365. // int ftruncate(int fd, off_t length);
  366. func Xftruncate(t *TLS, fd int32, length types.Off_t) int32 {
  367. if __ccgo_strace {
  368. trc("t=%v fd=%v length=%v, (%v:)", t, fd, length, origin(2))
  369. }
  370. if err := unix.Ftruncate(int(fd), int64(length)); err != nil {
  371. if dmesgs {
  372. dmesg("%v: fd %d: %v FAIL", origin(1), fd, err)
  373. }
  374. t.setErrno(err)
  375. return -1
  376. }
  377. if dmesgs {
  378. dmesg("%v: fd %d length %#0x: ok", origin(1), fd, length)
  379. }
  380. return 0
  381. }
  382. // int fcntl(int fd, int cmd, ... /* arg */ );
  383. func Xfcntl(t *TLS, fd, cmd int32, args uintptr) int32 {
  384. if __ccgo_strace {
  385. trc("t=%v cmd=%v args=%v, (%v:)", t, cmd, args, origin(2))
  386. }
  387. return Xfcntl64(t, fd, cmd, args)
  388. }
  389. // ssize_t read(int fd, void *buf, size_t count);
  390. func Xread(t *TLS, fd int32, buf uintptr, count types.Size_t) types.Ssize_t {
  391. if __ccgo_strace {
  392. trc("t=%v fd=%v buf=%v count=%v, (%v:)", t, fd, buf, count, origin(2))
  393. }
  394. var n int
  395. var err error
  396. switch {
  397. case count == 0:
  398. n, err = unix.Read(int(fd), nil)
  399. default:
  400. n, err = unix.Read(int(fd), (*RawMem)(unsafe.Pointer(buf))[:count:count])
  401. if dmesgs && err == nil {
  402. dmesg("%v: fd %v, count %#x, n %#x\n%s", origin(1), fd, count, n, hex.Dump((*RawMem)(unsafe.Pointer(buf))[:n:n]))
  403. }
  404. }
  405. if err != nil {
  406. if dmesgs {
  407. dmesg("%v: fd %v, %v FAIL", origin(1), fd, err)
  408. }
  409. t.setErrno(err)
  410. return -1
  411. }
  412. if dmesgs {
  413. dmesg("%v: ok", origin(1))
  414. }
  415. return types.Ssize_t(n)
  416. }
  417. // ssize_t write(int fd, const void *buf, size_t count);
  418. func Xwrite(t *TLS, fd int32, buf uintptr, count types.Size_t) types.Ssize_t {
  419. if __ccgo_strace {
  420. trc("t=%v fd=%v buf=%v count=%v, (%v:)", t, fd, buf, count, origin(2))
  421. }
  422. var n int
  423. var err error
  424. switch {
  425. case count == 0:
  426. n, err = unix.Write(int(fd), nil)
  427. default:
  428. n, err = unix.Write(int(fd), (*RawMem)(unsafe.Pointer(buf))[:count:count])
  429. if dmesgs {
  430. dmesg("%v: fd %v, count %#x\n%s", origin(1), fd, count, hex.Dump((*RawMem)(unsafe.Pointer(buf))[:count:count]))
  431. }
  432. }
  433. if err != nil {
  434. if dmesgs {
  435. dmesg("%v: %v FAIL", origin(1), err)
  436. }
  437. t.setErrno(err)
  438. return -1
  439. }
  440. if dmesgs {
  441. dmesg("%v: ok", origin(1))
  442. }
  443. return types.Ssize_t(n)
  444. }
  445. // int fchmod(int fd, mode_t mode);
  446. func Xfchmod(t *TLS, fd int32, mode types.Mode_t) int32 {
  447. if __ccgo_strace {
  448. trc("t=%v fd=%v mode=%v, (%v:)", t, fd, mode, origin(2))
  449. }
  450. if err := unix.Fchmod(int(fd), uint32(mode)); err != nil {
  451. t.setErrno(err)
  452. return -1
  453. }
  454. // if dmesgs {
  455. // dmesg("%v: %d %#o: ok", origin(1), fd, mode)
  456. // }
  457. return 0
  458. }
  459. // int fchown(int fd, uid_t owner, gid_t group);
  460. func Xfchown(t *TLS, fd int32, owner types.Uid_t, group types.Gid_t) int32 {
  461. if __ccgo_strace {
  462. trc("t=%v fd=%v owner=%v group=%v, (%v:)", t, fd, owner, group, origin(2))
  463. }
  464. if err := unix.Fchown(int(fd), int(owner), int(group)); err != nil {
  465. t.setErrno(err)
  466. return -1
  467. }
  468. return 0
  469. }
  470. // uid_t geteuid(void);
  471. func Xgeteuid(t *TLS) types.Uid_t {
  472. if __ccgo_strace {
  473. trc("t=%v, (%v:)", t, origin(2))
  474. }
  475. n := unix.Geteuid()
  476. return types.Uid_t(n)
  477. }
  478. // int munmap(void *addr, size_t length);
  479. func Xmunmap(t *TLS, addr uintptr, length types.Size_t) int32 {
  480. if __ccgo_strace {
  481. trc("t=%v addr=%v length=%v, (%v:)", t, addr, length, origin(2))
  482. }
  483. b := unsafe.Slice((*byte)(unsafe.Pointer(addr)), length)
  484. if err := unix.Munmap(b); err != nil {
  485. t.setErrno(err)
  486. return -1
  487. }
  488. return 0
  489. }
  490. // int gettimeofday(struct timeval *tv, struct timezone *tz);
  491. func Xgettimeofday(t *TLS, tv, tz uintptr) int32 {
  492. if __ccgo_strace {
  493. trc("t=%v tz=%v, (%v:)", t, tz, origin(2))
  494. }
  495. if tz != 0 {
  496. panic(todo(""))
  497. }
  498. var tvs unix.Timeval
  499. err := unix.Gettimeofday(&tvs)
  500. if err != nil {
  501. t.setErrno(err)
  502. return -1
  503. }
  504. *(*unix.Timeval)(unsafe.Pointer(tv)) = tvs
  505. return 0
  506. }
  507. // int getsockopt(int sockfd, int level, int optname, void *optval, socklen_t *optlen);
  508. func Xgetsockopt(t *TLS, sockfd, level, optname int32, optval, optlen uintptr) int32 {
  509. if __ccgo_strace {
  510. trc("t=%v optname=%v optlen=%v, (%v:)", t, optname, optlen, origin(2))
  511. }
  512. if _, _, err := unix.Syscall6(unix.SYS_GETSOCKOPT, uintptr(sockfd), uintptr(level), uintptr(optname), optval, optlen, 0); err != 0 {
  513. panic(todo("", "will fail on OpenBSD 7.5"))
  514. t.setErrno(err)
  515. return -1
  516. }
  517. return 0
  518. }
  519. // int setsockopt(int sockfd, int level, int optname, const void *optval, socklen_t optlen);
  520. func Xsetsockopt(t *TLS, sockfd, level, optname int32, optval uintptr, optlen socket.Socklen_t) int32 {
  521. if __ccgo_strace {
  522. trc("t=%v optname=%v optval=%v optlen=%v, (%v:)", t, optname, optval, optlen, origin(2))
  523. }
  524. if _, _, err := unix.Syscall6(unix.SYS_SETSOCKOPT, uintptr(sockfd), uintptr(level), uintptr(optname), optval, uintptr(optlen), 0); err != 0 {
  525. t.setErrno(err)
  526. panic(todo("", "will fail on OpenBSD 7.5"))
  527. return -1
  528. }
  529. return 0
  530. }
  531. // int ioctl(int fd, unsigned long request, ...);
  532. func Xioctl(t *TLS, fd int32, request ulong, va uintptr) int32 {
  533. if __ccgo_strace {
  534. trc("t=%v fd=%v request=%v va=%v, (%v:)", t, fd, request, va, origin(2))
  535. }
  536. var argp uintptr
  537. if va != 0 {
  538. argp = VaUintptr(&va)
  539. }
  540. n, _, err := unix.Syscall(unix.SYS_IOCTL, uintptr(fd), uintptr(request), argp)
  541. if err != 0 {
  542. t.setErrno(err)
  543. panic(todo("", "will fail on OpenBSD 7.5"))
  544. return -1
  545. }
  546. return int32(n)
  547. }
  548. // int getsockname(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
  549. func Xgetsockname(t *TLS, sockfd int32, addr, addrlen uintptr) int32 {
  550. if __ccgo_strace {
  551. trc("t=%v sockfd=%v addrlen=%v, (%v:)", t, sockfd, addrlen, origin(2))
  552. }
  553. sn, err := unix.Getsockname(int(sockfd))
  554. if err != nil {
  555. if dmesgs {
  556. dmesg("%v: fd %v: %v", origin(1), sockfd, err)
  557. }
  558. t.setErrno(err)
  559. return -1
  560. }
  561. *(*unix.Sockaddr)(unsafe.Pointer(addr)) = sn
  562. return 0
  563. }
  564. // int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout);
  565. func Xselect(t *TLS, nfds int32, readfds, writefds, exceptfds, timeout uintptr) int32 {
  566. if __ccgo_strace {
  567. trc("t=%v nfds=%v timeout=%v, (%v:)", t, nfds, timeout, origin(2))
  568. }
  569. n, err := unix.Select(
  570. int(nfds),
  571. (*unix.FdSet)(unsafe.Pointer(readfds)),
  572. (*unix.FdSet)(unsafe.Pointer(writefds)),
  573. (*unix.FdSet)(unsafe.Pointer(exceptfds)),
  574. (*unix.Timeval)(unsafe.Pointer(timeout)),
  575. )
  576. if err != nil {
  577. t.setErrno(err)
  578. return -1
  579. }
  580. return int32(n)
  581. }
  582. // int mkfifo(const char *pathname, mode_t mode);
  583. func Xmkfifo(t *TLS, pathname uintptr, mode types.Mode_t) int32 {
  584. if __ccgo_strace {
  585. trc("t=%v pathname=%v mode=%v, (%v:)", t, pathname, mode, origin(2))
  586. }
  587. if err := unix.Mkfifo(GoString(pathname), uint32(mode)); err != nil {
  588. t.setErrno(err)
  589. return -1
  590. }
  591. return 0
  592. }
  593. // mode_t umask(mode_t mask);
  594. func Xumask(t *TLS, mask types.Mode_t) types.Mode_t {
  595. if __ccgo_strace {
  596. trc("t=%v mask=%v, (%v:)", t, mask, origin(2))
  597. }
  598. return types.Mode_t(unix.Umask(int(mask)))
  599. }
  600. // int execvp(const char *file, char *const argv[]);
  601. func Xexecvp(t *TLS, file, argv uintptr) int32 {
  602. if __ccgo_strace {
  603. trc("t=%v argv=%v, (%v:)", t, argv, origin(2))
  604. }
  605. if err := unix.Exec(GoString(file), getVaList(argv), GetEnviron()); err != nil {
  606. t.setErrno(err)
  607. return -1
  608. }
  609. return 0
  610. }
  611. // pid_t waitpid(pid_t pid, int *wstatus, int options);
  612. func Xwaitpid(t *TLS, pid types.Pid_t, wstatus uintptr, optname int32) types.Pid_t {
  613. if __ccgo_strace {
  614. trc("t=%v pid=%v wstatus=%v optname=%v, (%v:)", t, pid, wstatus, optname, origin(2))
  615. }
  616. n, err := unix.Wait4(int(pid), (*unix.WaitStatus)(unsafe.Pointer(wstatus)), int(optname), nil)
  617. if err != nil {
  618. if dmesgs {
  619. dmesg("%v: %v FAIL", origin(1), err)
  620. }
  621. t.setErrno(err)
  622. return -1
  623. }
  624. if dmesgs {
  625. dmesg("%v: ok", origin(1))
  626. }
  627. return types.Pid_t(n)
  628. }
  629. // int uname(struct utsname *buf);
  630. func Xuname(t *TLS, buf uintptr) int32 {
  631. if __ccgo_strace {
  632. trc("t=%v buf=%v, (%v:)", t, buf, origin(2))
  633. }
  634. if err := unix.Uname((*unix.Utsname)(unsafe.Pointer(buf))); err != nil {
  635. if dmesgs {
  636. dmesg("%v: %v FAIL", origin(1), err)
  637. }
  638. t.setErrno(err)
  639. return -1
  640. }
  641. if dmesgs {
  642. dmesg("%v: ok", origin(1))
  643. }
  644. return 0
  645. }
  646. // ssize_t recv(int sockfd, void *buf, size_t len, int flags);
  647. func Xrecv(t *TLS, sockfd int32, buf uintptr, len types.Size_t, flags int32) types.Ssize_t {
  648. if __ccgo_strace {
  649. trc("t=%v sockfd=%v buf=%v len=%v flags=%v, (%v:)", t, sockfd, buf, len, flags, origin(2))
  650. }
  651. p := make([]byte, len)
  652. n, _, err := unix.Recvfrom(int(sockfd), p, int(flags))
  653. if err != nil {
  654. t.setErrno(err)
  655. return -1
  656. }
  657. copy((*RawMem)(unsafe.Pointer(buf))[:n:n], p[:])
  658. return types.Ssize_t(n)
  659. }
  660. // ssize_t send(int sockfd, const void *buf, size_t len, int flags);
  661. func Xsend(t *TLS, sockfd int32, buf uintptr, len types.Size_t, flags int32) types.Ssize_t {
  662. if __ccgo_strace {
  663. trc("t=%v sockfd=%v buf=%v len=%v flags=%v, (%v:)", t, sockfd, buf, len, flags, origin(2))
  664. }
  665. p := unsafe.Slice((*byte)(unsafe.Pointer(buf)), len)
  666. if err := unix.Send(int(sockfd), p, int(flags)); err != nil {
  667. t.setErrno(err)
  668. return -1
  669. }
  670. return types.Ssize_t(len)
  671. }
  672. // int shutdown(int sockfd, int how);
  673. func Xshutdown(t *TLS, sockfd, how int32) int32 {
  674. if __ccgo_strace {
  675. trc("t=%v how=%v, (%v:)", t, how, origin(2))
  676. }
  677. if err := unix.Shutdown(int(sockfd), int(how)); err != nil {
  678. t.setErrno(err)
  679. return -1
  680. }
  681. return 0
  682. }
  683. // int getpeername(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
  684. func Xgetpeername(t *TLS, sockfd int32, addr uintptr, addrlen uintptr) int32 {
  685. if __ccgo_strace {
  686. trc("t=%v sockfd=%v addr=%v addrlen=%v, (%v:)", t, sockfd, addr, addrlen, origin(2))
  687. }
  688. sa, err := unix.Getpeername(int(sockfd))
  689. if err != nil {
  690. t.setErrno(err)
  691. return -1
  692. }
  693. if __ccgo_strace {
  694. trc("sa=%v", sa)
  695. }
  696. panic(todo(""))
  697. // populate addr & addrlen from sa
  698. // , addr, uintptr(addrlen))
  699. return 0
  700. }
  701. // int socket(int domain, int type, int protocol);
  702. func Xsocket(t *TLS, domain, type1, protocol int32) int32 {
  703. if __ccgo_strace {
  704. trc("t=%v protocol=%v, (%v:)", t, protocol, origin(2))
  705. }
  706. fd, err := unix.Socket(int(domain), int(type1), int(protocol))
  707. if err != nil {
  708. t.setErrno(err)
  709. return -1
  710. }
  711. return int32(fd)
  712. }
  713. // int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
  714. func Xbind(t *TLS, sockfd int32, addr uintptr, addrlen uint32) int32 {
  715. if __ccgo_strace {
  716. trc("t=%v sockfd=%v addr=%v addrlen=%v, (%v:)", t, sockfd, addr, addrlen, origin(2))
  717. }
  718. if err := unix.Bind(int(sockfd), *(*unix.Sockaddr)(unsafe.Pointer(addr))); err != nil {
  719. t.setErrno(err)
  720. return -1
  721. }
  722. return 0
  723. }
  724. // int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
  725. func Xconnect(t *TLS, sockfd int32, addr uintptr, addrlen uint32) int32 {
  726. if __ccgo_strace {
  727. trc("t=%v sockfd=%v addr=%v addrlen=%v, (%v:)", t, sockfd, addr, addrlen, origin(2))
  728. }
  729. if err := unix.Connect(int(sockfd), *(*unix.Sockaddr)(unsafe.Pointer(addr))); err != nil {
  730. t.setErrno(err)
  731. return -1
  732. }
  733. return 0
  734. }
  735. // int listen(int sockfd, int backlog);
  736. func Xlisten(t *TLS, sockfd, backlog int32) int32 {
  737. if __ccgo_strace {
  738. trc("t=%v backlog=%v, (%v:)", t, backlog, origin(2))
  739. }
  740. if err := unix.Listen(int(sockfd), int(backlog)); err != nil {
  741. t.setErrno(err)
  742. return -1
  743. }
  744. return 0
  745. }
  746. // int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
  747. func Xaccept(t *TLS, sockfd int32, addr uintptr, addrlen uintptr) int32 {
  748. if __ccgo_strace {
  749. trc("t=%v sockfd=%v addr=%v addrlen=%v, (%v:)", t, sockfd, addr, addrlen, origin(2))
  750. }
  751. nfd, sa, err := unix.Accept(int(sockfd))
  752. if err != nil {
  753. t.setErrno(err)
  754. return -1
  755. }
  756. if __ccgo_strace {
  757. trc("sa=%v", sa)
  758. }
  759. panic(todo(""))
  760. // populate addr, addrlen from sa
  761. return int32(nfd)
  762. }
  763. // int getrlimit(int resource, struct rlimit *rlim);
  764. func Xgetrlimit(t *TLS, resource int32, rlim uintptr) int32 {
  765. if __ccgo_strace {
  766. trc("t=%v resource=%v rlim=%v, (%v:)", t, resource, rlim, origin(2))
  767. }
  768. return Xgetrlimit64(t, resource, rlim)
  769. }
  770. // int setrlimit(int resource, const struct rlimit *rlim);
  771. func Xsetrlimit(t *TLS, resource int32, rlim uintptr) int32 {
  772. if __ccgo_strace {
  773. trc("t=%v resource=%v rlim=%v, (%v:)", t, resource, rlim, origin(2))
  774. }
  775. return Xsetrlimit64(t, resource, rlim)
  776. }
  777. // int setrlimit(int resource, const struct rlimit *rlim);
  778. func Xsetrlimit64(t *TLS, resource int32, rlim uintptr) int32 {
  779. if __ccgo_strace {
  780. trc("t=%v resource=%v rlim=%v, (%v:)", t, resource, rlim, origin(2))
  781. }
  782. if err := unix.Setrlimit(int(resource), (*unix.Rlimit)(unsafe.Pointer(rlim))); err != nil {
  783. t.setErrno(err)
  784. return -1
  785. }
  786. return 0
  787. }
  788. // uid_t getuid(void);
  789. func Xgetuid(t *TLS) types.Uid_t {
  790. if __ccgo_strace {
  791. trc("t=%v, (%v:)", t, origin(2))
  792. }
  793. return types.Uid_t(os.Getuid())
  794. }
  795. // pid_t getpid(void);
  796. func Xgetpid(t *TLS) int32 {
  797. if __ccgo_strace {
  798. trc("t=%v, (%v:)", t, origin(2))
  799. }
  800. return int32(os.Getpid())
  801. }
  802. // int system(const char *command);
  803. func Xsystem(t *TLS, command uintptr) int32 {
  804. if __ccgo_strace {
  805. trc("t=%v command=%v, (%v:)", t, command, origin(2))
  806. }
  807. s := GoString(command)
  808. if command == 0 {
  809. panic(todo(""))
  810. }
  811. cmd := exec.Command("sh", "-c", s)
  812. cmd.Stdout = os.Stdout
  813. cmd.Stderr = os.Stderr
  814. err := cmd.Run()
  815. if err != nil {
  816. ps := err.(*exec.ExitError)
  817. return int32(ps.ExitCode())
  818. }
  819. return 0
  820. }
  821. // int setvbuf(FILE *stream, char *buf, int mode, size_t size);
  822. func Xsetvbuf(t *TLS, stream, buf uintptr, mode int32, size types.Size_t) int32 {
  823. if __ccgo_strace {
  824. trc("t=%v buf=%v mode=%v size=%v, (%v:)", t, buf, mode, size, origin(2))
  825. }
  826. return 0 //TODO
  827. }
  828. // int raise(int sig);
  829. func Xraise(t *TLS, sig int32) int32 {
  830. if __ccgo_strace {
  831. trc("t=%v sig=%v, (%v:)", t, sig, origin(2))
  832. }
  833. panic(todo(""))
  834. }
  835. // int backtrace(void **buffer, int size);
  836. func Xbacktrace(t *TLS, buf uintptr, size int32) int32 {
  837. if __ccgo_strace {
  838. trc("t=%v buf=%v size=%v, (%v:)", t, buf, size, origin(2))
  839. }
  840. panic(todo(""))
  841. }
  842. // void backtrace_symbols_fd(void *const *buffer, int size, int fd);
  843. func Xbacktrace_symbols_fd(t *TLS, buffer uintptr, size, fd int32) {
  844. if __ccgo_strace {
  845. trc("t=%v buffer=%v fd=%v, (%v:)", t, buffer, fd, origin(2))
  846. }
  847. panic(todo(""))
  848. }
  849. // int fileno(FILE *stream);
  850. func Xfileno(t *TLS, stream uintptr) int32 {
  851. if __ccgo_strace {
  852. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  853. }
  854. panic(todo(""))
  855. }
  856. func newCFtsent(t *TLS, info int, path string, stat *unix.Stat_t, err syscallErrno) uintptr {
  857. p := Xcalloc(t, 1, types.Size_t(unsafe.Sizeof(fts.FTSENT{})))
  858. if p == 0 {
  859. panic("OOM")
  860. }
  861. *(*fts.FTSENT)(unsafe.Pointer(p)) = *newFtsent(t, info, path, stat, err)
  862. return p
  863. }
  864. func ftsentClose(t *TLS, p uintptr) {
  865. Xfree(t, (*fts.FTSENT)(unsafe.Pointer(p)).Ffts_path)
  866. Xfree(t, (*fts.FTSENT)(unsafe.Pointer(p)).Ffts_statp)
  867. }
  868. type ftstream struct {
  869. s []uintptr
  870. x int
  871. }
  872. func (f *ftstream) close(t *TLS) {
  873. for _, p := range f.s {
  874. ftsentClose(t, p)
  875. Xfree(t, p)
  876. }
  877. *f = ftstream{}
  878. }
  879. // FTS *fts_open(char * const *path_argv, int options, int (*compar)(const FTSENT **, const FTSENT **));
  880. func Xfts_open(t *TLS, path_argv uintptr, options int32, compar uintptr) uintptr {
  881. if __ccgo_strace {
  882. trc("t=%v path_argv=%v options=%v compar=%v, (%v:)", t, path_argv, options, compar, origin(2))
  883. }
  884. return Xfts64_open(t, path_argv, options, compar)
  885. }
  886. // FTS *fts_open(char * const *path_argv, int options, int (*compar)(const FTSENT **, const FTSENT **));
  887. func Xfts64_open(t *TLS, path_argv uintptr, options int32, compar uintptr) uintptr {
  888. if __ccgo_strace {
  889. trc("t=%v path_argv=%v options=%v compar=%v, (%v:)", t, path_argv, options, compar, origin(2))
  890. }
  891. f := &ftstream{}
  892. var walk func(string)
  893. walk = func(path string) {
  894. var fi os.FileInfo
  895. var err error
  896. switch {
  897. case options&fts.FTS_LOGICAL != 0:
  898. fi, err = os.Stat(path)
  899. case options&fts.FTS_PHYSICAL != 0:
  900. fi, err = os.Lstat(path)
  901. default:
  902. panic(todo(""))
  903. }
  904. if err != nil {
  905. return
  906. }
  907. var statp *unix.Stat_t
  908. if options&fts.FTS_NOSTAT == 0 {
  909. var stat unix.Stat_t
  910. switch {
  911. case options&fts.FTS_LOGICAL != 0:
  912. if err := unix.Stat(path, &stat); err != nil {
  913. panic(todo(""))
  914. }
  915. case options&fts.FTS_PHYSICAL != 0:
  916. if err := unix.Lstat(path, &stat); err != nil {
  917. panic(todo(""))
  918. }
  919. default:
  920. panic(todo(""))
  921. }
  922. statp = &stat
  923. }
  924. out:
  925. switch {
  926. case fi.IsDir():
  927. f.s = append(f.s, newCFtsent(t, fts.FTS_D, path, statp, 0))
  928. g, err := os.Open(path)
  929. switch x := err.(type) {
  930. case nil:
  931. // ok
  932. case *os.PathError:
  933. f.s = append(f.s, newCFtsent(t, fts.FTS_DNR, path, statp, errno.EACCES))
  934. break out
  935. default:
  936. panic(todo("%q: %v %T", path, x, x))
  937. }
  938. names, err := g.Readdirnames(-1)
  939. g.Close()
  940. if err != nil {
  941. panic(todo(""))
  942. }
  943. for _, name := range names {
  944. walk(path + "/" + name)
  945. if f == nil {
  946. break out
  947. }
  948. }
  949. f.s = append(f.s, newCFtsent(t, fts.FTS_DP, path, statp, 0))
  950. default:
  951. info := fts.FTS_F
  952. if fi.Mode()&os.ModeSymlink != 0 {
  953. info = fts.FTS_SL
  954. }
  955. switch {
  956. case statp != nil:
  957. f.s = append(f.s, newCFtsent(t, info, path, statp, 0))
  958. case options&fts.FTS_NOSTAT != 0:
  959. f.s = append(f.s, newCFtsent(t, fts.FTS_NSOK, path, nil, 0))
  960. default:
  961. panic(todo(""))
  962. }
  963. }
  964. }
  965. for {
  966. p := *(*uintptr)(unsafe.Pointer(path_argv))
  967. if p == 0 {
  968. if f == nil {
  969. return 0
  970. }
  971. if compar != 0 {
  972. panic(todo(""))
  973. }
  974. return addObject(f)
  975. }
  976. walk(GoString(p))
  977. path_argv += unsafe.Sizeof(uintptr(0))
  978. }
  979. }
  980. // FTSENT *fts_read(FTS *ftsp);
  981. func Xfts_read(t *TLS, ftsp uintptr) uintptr {
  982. if __ccgo_strace {
  983. trc("t=%v ftsp=%v, (%v:)", t, ftsp, origin(2))
  984. }
  985. return Xfts64_read(t, ftsp)
  986. }
  987. // FTSENT *fts_read(FTS *ftsp);
  988. func Xfts64_read(t *TLS, ftsp uintptr) uintptr {
  989. if __ccgo_strace {
  990. trc("t=%v ftsp=%v, (%v:)", t, ftsp, origin(2))
  991. }
  992. f := getObject(ftsp).(*ftstream)
  993. if f.x == len(f.s) {
  994. t.setErrno(0)
  995. return 0
  996. }
  997. r := f.s[f.x]
  998. if e := (*fts.FTSENT)(unsafe.Pointer(r)).Ffts_errno; e != 0 {
  999. t.setErrno(e)
  1000. }
  1001. f.x++
  1002. return r
  1003. }
  1004. // int fts_close(FTS *ftsp);
  1005. func Xfts_close(t *TLS, ftsp uintptr) int32 {
  1006. if __ccgo_strace {
  1007. trc("t=%v ftsp=%v, (%v:)", t, ftsp, origin(2))
  1008. }
  1009. return Xfts64_close(t, ftsp)
  1010. }
  1011. // int fts_close(FTS *ftsp);
  1012. func Xfts64_close(t *TLS, ftsp uintptr) int32 {
  1013. if __ccgo_strace {
  1014. trc("t=%v ftsp=%v, (%v:)", t, ftsp, origin(2))
  1015. }
  1016. getObject(ftsp).(*ftstream).close(t)
  1017. removeObject(ftsp)
  1018. return 0
  1019. }
  1020. // void tzset (void);
  1021. func Xtzset(t *TLS) {
  1022. if __ccgo_strace {
  1023. trc("t=%v, (%v:)", t, origin(2))
  1024. }
  1025. //TODO
  1026. }
  1027. var strerrorBuf [100]byte
  1028. // char *strerror(int errnum);
  1029. func Xstrerror(t *TLS, errnum int32) uintptr {
  1030. if __ccgo_strace {
  1031. trc("t=%v errnum=%v, (%v:)", t, errnum, origin(2))
  1032. }
  1033. if dmesgs {
  1034. dmesg("%v: %v\n%s", origin(1), errnum, debug.Stack())
  1035. }
  1036. copy(strerrorBuf[:], fmt.Sprintf("strerror(%d)\x00", errnum))
  1037. return uintptr(unsafe.Pointer(&strerrorBuf[0]))
  1038. }
  1039. // void *dlopen(const char *filename, int flags);
  1040. func Xdlopen(t *TLS, filename uintptr, flags int32) uintptr {
  1041. if __ccgo_strace {
  1042. trc("t=%v filename=%v flags=%v, (%v:)", t, filename, flags, origin(2))
  1043. }
  1044. panic(todo(""))
  1045. }
  1046. // char *dlerror(void);
  1047. func Xdlerror(t *TLS) uintptr {
  1048. if __ccgo_strace {
  1049. trc("t=%v, (%v:)", t, origin(2))
  1050. }
  1051. panic(todo(""))
  1052. }
  1053. // int dlclose(void *handle);
  1054. func Xdlclose(t *TLS, handle uintptr) int32 {
  1055. if __ccgo_strace {
  1056. trc("t=%v handle=%v, (%v:)", t, handle, origin(2))
  1057. }
  1058. panic(todo(""))
  1059. }
  1060. // void *dlsym(void *handle, const char *symbol);
  1061. func Xdlsym(t *TLS, handle, symbol uintptr) uintptr {
  1062. if __ccgo_strace {
  1063. trc("t=%v symbol=%v, (%v:)", t, symbol, origin(2))
  1064. }
  1065. panic(todo(""))
  1066. }
  1067. // void perror(const char *s);
  1068. func Xperror(t *TLS, s uintptr) {
  1069. if __ccgo_strace {
  1070. trc("t=%v s=%v, (%v:)", t, s, origin(2))
  1071. }
  1072. panic(todo(""))
  1073. }
  1074. // int pclose(FILE *stream);
  1075. func Xpclose(t *TLS, stream uintptr) int32 {
  1076. if __ccgo_strace {
  1077. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1078. }
  1079. panic(todo(""))
  1080. }
  1081. var gai_strerrorBuf [100]byte
  1082. // const char *gai_strerror(int errcode);
  1083. func Xgai_strerror(t *TLS, errcode int32) uintptr {
  1084. if __ccgo_strace {
  1085. trc("t=%v errcode=%v, (%v:)", t, errcode, origin(2))
  1086. }
  1087. copy(gai_strerrorBuf[:], fmt.Sprintf("gai error %d\x00", errcode))
  1088. return uintptr(unsafe.Pointer(&gai_strerrorBuf))
  1089. }
  1090. // int tcgetattr(int fd, struct termios *termios_p);
  1091. func Xtcgetattr(t *TLS, fd int32, termios_p uintptr) int32 {
  1092. if __ccgo_strace {
  1093. trc("t=%v fd=%v termios_p=%v, (%v:)", t, fd, termios_p, origin(2))
  1094. }
  1095. panic(todo(""))
  1096. }
  1097. // int tcsetattr(int fd, int optional_actions, const struct termios *termios_p);
  1098. func Xtcsetattr(t *TLS, fd, optional_actions int32, termios_p uintptr) int32 {
  1099. if __ccgo_strace {
  1100. trc("t=%v optional_actions=%v termios_p=%v, (%v:)", t, optional_actions, termios_p, origin(2))
  1101. }
  1102. panic(todo(""))
  1103. }
  1104. // speed_t cfgetospeed(const struct termios *termios_p);
  1105. func Xcfgetospeed(t *TLS, termios_p uintptr) termios.Speed_t {
  1106. if __ccgo_strace {
  1107. trc("t=%v termios_p=%v, (%v:)", t, termios_p, origin(2))
  1108. }
  1109. panic(todo(""))
  1110. }
  1111. // int cfsetospeed(struct termios *termios_p, speed_t speed);
  1112. func Xcfsetospeed(t *TLS, termios_p uintptr, speed uint32) int32 {
  1113. if __ccgo_strace {
  1114. trc("t=%v termios_p=%v speed=%v, (%v:)", t, termios_p, speed, origin(2))
  1115. }
  1116. panic(todo(""))
  1117. }
  1118. // int cfsetispeed(struct termios *termios_p, speed_t speed);
  1119. func Xcfsetispeed(t *TLS, termios_p uintptr, speed uint32) int32 {
  1120. if __ccgo_strace {
  1121. trc("t=%v termios_p=%v speed=%v, (%v:)", t, termios_p, speed, origin(2))
  1122. }
  1123. panic(todo(""))
  1124. }
  1125. // pid_t fork(void);
  1126. func Xfork(t *TLS) int32 {
  1127. if __ccgo_strace {
  1128. trc("t=%v, (%v:)", t, origin(2))
  1129. }
  1130. t.setErrno(errno.ENOSYS)
  1131. return -1
  1132. }
  1133. var emptyStr = [1]byte{}
  1134. // char *setlocale(int category, const char *locale);
  1135. func Xsetlocale(t *TLS, category int32, locale uintptr) uintptr {
  1136. if __ccgo_strace {
  1137. trc("t=%v category=%v locale=%v, (%v:)", t, category, locale, origin(2))
  1138. }
  1139. return uintptr(unsafe.Pointer(&emptyStr)) //TODO
  1140. }
  1141. // char *nl_langinfo(nl_item item);
  1142. func Xnl_langinfo(t *TLS, item langinfo.Nl_item) uintptr {
  1143. if __ccgo_strace {
  1144. trc("t=%v item=%v, (%v:)", t, item, origin(2))
  1145. }
  1146. return uintptr(unsafe.Pointer(&emptyStr)) //TODO
  1147. }
  1148. // FILE *popen(const char *command, const char *type);
  1149. func Xpopen(t *TLS, command, type1 uintptr) uintptr {
  1150. if __ccgo_strace {
  1151. trc("t=%v type1=%v, (%v:)", t, type1, origin(2))
  1152. }
  1153. panic(todo(""))
  1154. }
  1155. // char *realpath(const char *path, char *resolved_path);
  1156. func Xrealpath(t *TLS, path, resolved_path uintptr) uintptr {
  1157. if __ccgo_strace {
  1158. trc("t=%v resolved_path=%v, (%v:)", t, resolved_path, origin(2))
  1159. }
  1160. s, err := filepath.EvalSymlinks(GoString(path))
  1161. if err != nil {
  1162. if os.IsNotExist(err) {
  1163. // if dmesgs {
  1164. // dmesg("%v: %q: %v", origin(1), GoString(path), err)
  1165. // }
  1166. t.setErrno(errno.ENOENT)
  1167. return 0
  1168. }
  1169. panic(todo("", err))
  1170. }
  1171. if resolved_path == 0 {
  1172. panic(todo(""))
  1173. }
  1174. if len(s) >= limits.PATH_MAX {
  1175. s = s[:limits.PATH_MAX-1]
  1176. }
  1177. copy((*RawMem)(unsafe.Pointer(resolved_path))[:len(s):len(s)], s)
  1178. (*RawMem)(unsafe.Pointer(resolved_path))[len(s)] = 0
  1179. return resolved_path
  1180. }
  1181. // char *inet_ntoa(struct in_addr in);
  1182. func Xinet_ntoa(t *TLS, in1 in.In_addr) uintptr {
  1183. if __ccgo_strace {
  1184. trc("t=%v in1=%v, (%v:)", t, in1, origin(2))
  1185. }
  1186. panic(todo(""))
  1187. }
  1188. func X__ccgo_in6addr_anyp(t *TLS) uintptr {
  1189. if __ccgo_strace {
  1190. trc("t=%v, (%v:)", t, origin(2))
  1191. }
  1192. return uintptr(unsafe.Pointer(&in6_addr_any))
  1193. }
  1194. func Xabort(t *TLS) {
  1195. if __ccgo_strace {
  1196. trc("t=%v, (%v:)", t, origin(2))
  1197. }
  1198. panic(todo("")) //TODO
  1199. // if dmesgs {
  1200. // dmesg("%v:", origin(1))
  1201. // }
  1202. // p := Xcalloc(t, 1, types.Size_t(unsafe.Sizeof(signal.Sigaction{})))
  1203. // if p == 0 {
  1204. // panic("OOM")
  1205. // }
  1206. // (*signal.Sigaction)(unsafe.Pointer(p)).F__sigaction_u.F__sa_handler = signal.SIG_DFL
  1207. // Xsigaction(t, signal.SIGABRT, p, 0)
  1208. // Xfree(t, p)
  1209. // unix.Kill(unix.Getpid(), unix.Signal(signal.SIGABRT))
  1210. // panic(todo("unrechable"))
  1211. }
  1212. // int fflush(FILE *stream);
  1213. func Xfflush(t *TLS, stream uintptr) int32 {
  1214. if __ccgo_strace {
  1215. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1216. }
  1217. return 0 //TODO
  1218. }
  1219. // size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
  1220. func Xfread(t *TLS, ptr uintptr, size, nmemb types.Size_t, stream uintptr) types.Size_t {
  1221. if __ccgo_strace {
  1222. trc("t=%v ptr=%+v nmemb=%d stream=%v, (%v:)", t, unsafe.Slice((*byte)(unsafe.Pointer(ptr)), nmemb), nmemb, *(*int32)(unsafe.Pointer(stream)), origin(2))
  1223. }
  1224. buf := unsafe.Slice((*byte)(unsafe.Pointer(ptr)), nmemb*size)
  1225. m, err := unix.Read(int(file(stream).fd()), buf)
  1226. if err != nil {
  1227. file(stream).setErr()
  1228. return 0
  1229. }
  1230. if dmesgs {
  1231. // // dmesg("%v: %d %#x x %#x: %#x\n%s", origin(1), file(stream).fd(), size, nmemb, types.Size_t(m)/size, hex.Dump(GoBytes(ptr, int(m))))
  1232. dmesg("%v: %d %#x x %#x: %#x", origin(1), file(stream).fd(), size, nmemb, types.Size_t(m)/size)
  1233. }
  1234. return types.Size_t(m) / size
  1235. }
  1236. // size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);
  1237. func Xfwrite(t *TLS, ptr uintptr, size, nmemb types.Size_t, stream uintptr) types.Size_t {
  1238. if __ccgo_strace {
  1239. trc("t=%v ptr=%v nmemb=%v stream=%v, (%v:)", t, ptr, nmemb, stream, origin(2))
  1240. }
  1241. buf := unsafe.Slice((*byte)(unsafe.Pointer(ptr)), nmemb*size)
  1242. m, err := unix.Write(int(file(stream).fd()), buf)
  1243. if err != nil {
  1244. file(stream).setErr()
  1245. return 0
  1246. }
  1247. // if dmesgs {
  1248. // // dmesg("%v: %d %#x x %#x: %#x\n%s", origin(1), file(stream).fd(), size, nmemb, types.Size_t(m)/size, hex.Dump(GoBytes(ptr, int(m))))
  1249. // dmesg("%v: %d %#x x %#x: %#x", origin(1), file(stream).fd(), size, nmemb, types.Size_t(m)/size)
  1250. // }
  1251. return types.Size_t(m) / size
  1252. }
  1253. // int fclose(FILE *stream);
  1254. func Xfclose(t *TLS, stream uintptr) int32 {
  1255. if __ccgo_strace {
  1256. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1257. }
  1258. return file(stream).close(t)
  1259. }
  1260. // int fputc(int c, FILE *stream);
  1261. func Xfputc(t *TLS, c int32, stream uintptr) int32 {
  1262. if __ccgo_strace {
  1263. trc("t=%v c=%v stream=%v, (%v:)", t, c, stream, origin(2))
  1264. }
  1265. if _, err := fwrite(file(stream).fd(), []byte{byte(c)}); err != nil {
  1266. return stdio.EOF
  1267. }
  1268. return int32(byte(c))
  1269. }
  1270. // int fseek(FILE *stream, long offset, int whence);
  1271. func Xfseek(t *TLS, stream uintptr, offset long, whence int32) int32 {
  1272. if __ccgo_strace {
  1273. trc("t=%v stream=%v offset=%v whence=%v, (%v:)", t, stream, offset, whence, origin(2))
  1274. }
  1275. if n := Xlseek(t, int32(file(stream).fd()), types.Off_t(offset), whence); n < 0 {
  1276. // if dmesgs {
  1277. // dmesg("%v: fd %v, off %#x, whence %v: %v", origin(1), file(stream).fd(), offset, whenceStr(whence), n)
  1278. // }
  1279. file(stream).setErr()
  1280. return -1
  1281. }
  1282. // if dmesgs {
  1283. // dmesg("%v: fd %v, off %#x, whence %v: ok", origin(1), file(stream).fd(), offset, whenceStr(whence))
  1284. // }
  1285. return 0
  1286. }
  1287. // long ftell(FILE *stream);
  1288. func Xftell(t *TLS, stream uintptr) long {
  1289. if __ccgo_strace {
  1290. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1291. }
  1292. n := Xlseek(t, file(stream).fd(), 0, stdio.SEEK_CUR)
  1293. if n < 0 {
  1294. file(stream).setErr()
  1295. return -1
  1296. }
  1297. // if dmesgs {
  1298. // dmesg("%v: fd %v, n %#x: ok %#x", origin(1), file(stream).fd(), n, long(n))
  1299. // }
  1300. return long(n)
  1301. }
  1302. // int ferror(FILE *stream);
  1303. func Xferror(t *TLS, stream uintptr) int32 {
  1304. if __ccgo_strace {
  1305. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1306. }
  1307. return Bool32(file(stream).err())
  1308. }
  1309. // int ungetc(int c, FILE *stream);
  1310. func Xungetc(t *TLS, c int32, stream uintptr) int32 {
  1311. if __ccgo_strace {
  1312. trc("t=%v c=%v stream=%v, (%v:)", t, c, stream, origin(2))
  1313. }
  1314. panic(todo(""))
  1315. }
  1316. // int fscanf(FILE *stream, const char *format, ...);
  1317. func Xfscanf(t *TLS, stream, format, va uintptr) int32 {
  1318. if __ccgo_strace {
  1319. trc("t=%v va=%v, (%v:)", t, va, origin(2))
  1320. }
  1321. panic(todo(""))
  1322. }
  1323. // int fputs(const char *s, FILE *stream);
  1324. func Xfputs(t *TLS, s, stream uintptr) int32 {
  1325. if __ccgo_strace {
  1326. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1327. }
  1328. buf := unsafe.Slice((*byte)(unsafe.Pointer(s)), uintptr(Xstrlen(t, s)))
  1329. if _, err := unix.Write(int(file(stream).fd()), buf); err != nil {
  1330. return -1
  1331. }
  1332. return 0
  1333. }
  1334. var getservbynameStaticResult netdb.Servent
  1335. // struct servent *getservbyname(const char *name, const char *proto);
  1336. func Xgetservbyname(t *TLS, name, proto uintptr) uintptr {
  1337. if __ccgo_strace {
  1338. trc("t=%v proto=%v, (%v:)", t, proto, origin(2))
  1339. }
  1340. var protoent *gonetdb.Protoent
  1341. if proto != 0 {
  1342. protoent = gonetdb.GetProtoByName(GoString(proto))
  1343. }
  1344. servent := gonetdb.GetServByName(GoString(name), protoent)
  1345. if servent == nil {
  1346. // if dmesgs {
  1347. // dmesg("%q %q: nil (protoent %+v)", GoString(name), GoString(proto), protoent)
  1348. // }
  1349. return 0
  1350. }
  1351. Xfree(t, (*netdb.Servent)(unsafe.Pointer(&getservbynameStaticResult)).Fs_name)
  1352. if v := (*netdb.Servent)(unsafe.Pointer(&getservbynameStaticResult)).Fs_aliases; v != 0 {
  1353. for {
  1354. p := *(*uintptr)(unsafe.Pointer(v))
  1355. if p == 0 {
  1356. break
  1357. }
  1358. Xfree(t, p)
  1359. v += unsafe.Sizeof(uintptr(0))
  1360. }
  1361. Xfree(t, v)
  1362. }
  1363. Xfree(t, (*netdb.Servent)(unsafe.Pointer(&getservbynameStaticResult)).Fs_proto)
  1364. cname, err := CString(servent.Name)
  1365. if err != nil {
  1366. getservbynameStaticResult = netdb.Servent{}
  1367. return 0
  1368. }
  1369. var protoname uintptr
  1370. if protoent != nil {
  1371. if protoname, err = CString(protoent.Name); err != nil {
  1372. Xfree(t, cname)
  1373. getservbynameStaticResult = netdb.Servent{}
  1374. return 0
  1375. }
  1376. }
  1377. var a []uintptr
  1378. for _, v := range servent.Aliases {
  1379. cs, err := CString(v)
  1380. if err != nil {
  1381. for _, v := range a {
  1382. Xfree(t, v)
  1383. }
  1384. return 0
  1385. }
  1386. a = append(a, cs)
  1387. }
  1388. v := Xcalloc(t, types.Size_t(len(a)+1), types.Size_t(unsafe.Sizeof(uintptr(0))))
  1389. if v == 0 {
  1390. Xfree(t, cname)
  1391. Xfree(t, protoname)
  1392. for _, v := range a {
  1393. Xfree(t, v)
  1394. }
  1395. getservbynameStaticResult = netdb.Servent{}
  1396. return 0
  1397. }
  1398. for _, p := range a {
  1399. *(*uintptr)(unsafe.Pointer(v)) = p
  1400. v += unsafe.Sizeof(uintptr(0))
  1401. }
  1402. getservbynameStaticResult = netdb.Servent{
  1403. Fs_name: cname,
  1404. Fs_aliases: v,
  1405. Fs_port: int32(servent.Port),
  1406. Fs_proto: protoname,
  1407. }
  1408. return uintptr(unsafe.Pointer(&getservbynameStaticResult))
  1409. }
  1410. func Xreaddir64(t *TLS, dir uintptr) uintptr {
  1411. if __ccgo_strace {
  1412. trc("t=%v dir=%v, (%v:)", t, dir, origin(2))
  1413. }
  1414. return Xreaddir(t, dir)
  1415. }
  1416. func __syscall(r, _ uintptr, errno syscallErrno) long {
  1417. if errno != 0 {
  1418. return long(-errno)
  1419. }
  1420. return long(r)
  1421. }
  1422. func X__syscall1(t *TLS, trap, p1 long) long {
  1423. if __ccgo_strace {
  1424. trc("t=%v p1=%v, (%v:)", t, p1, origin(2))
  1425. }
  1426. return __syscall(unix.Syscall(uintptr(trap), uintptr(p1), 0, 0))
  1427. }
  1428. func X__syscall3(t *TLS, trap, p1, p2, p3 long) long {
  1429. if __ccgo_strace {
  1430. trc("t=%v p3=%v, (%v:)", t, p3, origin(2))
  1431. }
  1432. return __syscall(unix.Syscall(uintptr(trap), uintptr(p1), uintptr(p2), uintptr(p3)))
  1433. }
  1434. func X__syscall4(t *TLS, trap, p1, p2, p3, p4 long) long {
  1435. if __ccgo_strace {
  1436. trc("t=%v p4=%v, (%v:)", t, p4, origin(2))
  1437. }
  1438. return __syscall(unix.Syscall6(uintptr(trap), uintptr(p1), uintptr(p2), uintptr(p3), uintptr(p4), 0, 0))
  1439. }
  1440. func fcntlCmdStr(cmd int32) string {
  1441. switch cmd {
  1442. case fcntl.F_GETOWN:
  1443. return "F_GETOWN"
  1444. case fcntl.F_SETLK:
  1445. return "F_SETLK"
  1446. case fcntl.F_GETLK:
  1447. return "F_GETLK"
  1448. case fcntl.F_SETFD:
  1449. return "F_SETFD"
  1450. case fcntl.F_GETFD:
  1451. return "F_GETFD"
  1452. default:
  1453. return fmt.Sprintf("cmd(%d)", cmd)
  1454. }
  1455. }
  1456. // int setenv(const char *name, const char *value, int overwrite);
  1457. func Xsetenv(t *TLS, name, value uintptr, overwrite int32) int32 {
  1458. if __ccgo_strace {
  1459. trc("t=%v value=%v overwrite=%v, (%v:)", t, value, overwrite, origin(2))
  1460. }
  1461. panic(todo(""))
  1462. }
  1463. // int unsetenv(const char *name);
  1464. func Xunsetenv(t *TLS, name uintptr) int32 {
  1465. if __ccgo_strace {
  1466. trc("t=%v name=%v, (%v:)", t, name, origin(2))
  1467. }
  1468. panic(todo(""))
  1469. }
  1470. // int pause(void);
  1471. func Xpause(t *TLS) int32 {
  1472. if __ccgo_strace {
  1473. trc("t=%v, (%v:)", t, origin(2))
  1474. }
  1475. panic(todo(""))
  1476. }
  1477. // ssize_t writev(int fd, const struct iovec *iov, int iovcnt);
  1478. func Xwritev(t *TLS, fd int32, iov uintptr, iovcnt int32) types.Ssize_t {
  1479. if __ccgo_strace {
  1480. trc("t=%v fd=%v iov=%v iovcnt=%v, (%v:)", t, fd, iov, iovcnt, origin(2))
  1481. }
  1482. panic(todo(""))
  1483. }
  1484. // int __isoc99_sscanf(const char *str, const char *format, ...);
  1485. func X__isoc99_sscanf(t *TLS, str, format, va uintptr) int32 {
  1486. if __ccgo_strace {
  1487. trc("t=%v va=%v, (%v:)", t, va, origin(2))
  1488. }
  1489. r := Xsscanf(t, str, format, va)
  1490. // if dmesgs {
  1491. // dmesg("%v: %q %q: %d", origin(1), GoString(str), GoString(format), r)
  1492. // }
  1493. return r
  1494. }
  1495. // void __assert(const char * func, const char * file, int line, const char *expr) __dead2;
  1496. func X__assert(t *TLS, fn, file uintptr, line int32, expr uintptr) {
  1497. if __ccgo_strace {
  1498. trc("t=%v file=%v line=%v expr=%v, (%v:)", t, file, line, expr, origin(2))
  1499. }
  1500. X__assert_fail(t, expr, file, uint32(line), fn)
  1501. }
  1502. func X__assert13(t *TLS, file uintptr, line int32, fn, msg uintptr) {
  1503. if __ccgo_strace {
  1504. trc("t=%v file=%v line=%v msg=%v, (%v:)", t, file, line, msg, origin(2))
  1505. }
  1506. X__assert_fail(t, msg, file, uint32(line), fn)
  1507. }
  1508. // include/stdio.h:456:int __swbuf(int, FILE *);
  1509. func X__swbuf(t *TLS, n int32, file uintptr) int32 {
  1510. if __ccgo_strace {
  1511. trc("t=%v n=%v file=%v, (%v:)", t, n, file, origin(2))
  1512. }
  1513. return Xfputc(t, n, file) //TODO improve performance, use a real buffer.
  1514. }
  1515. // int rmdir(const char *pathname);
  1516. func Xrmdir(t *TLS, pathname uintptr) int32 {
  1517. if __ccgo_strace {
  1518. trc("t=%v pathname=%v, (%v:)", t, pathname, origin(2))
  1519. }
  1520. if err := unix.Rmdir(GoString(pathname)); err != nil {
  1521. if dmesgs {
  1522. dmesg("%v: %v FAIL", origin(1), err)
  1523. }
  1524. t.setErrno(err)
  1525. return -1
  1526. }
  1527. if dmesgs {
  1528. dmesg("%v: ok", origin(1))
  1529. }
  1530. return 0
  1531. }
  1532. // struct dirent *readdir(DIR *dirp);
  1533. func Xreaddir(t *TLS, dir uintptr) uintptr {
  1534. if __ccgo_strace {
  1535. trc("t=%v dir=%v, (%v:)", t, dir, origin(2))
  1536. }
  1537. if (*darwinDir)(unsafe.Pointer(dir)).eof {
  1538. return 0
  1539. }
  1540. if (*darwinDir)(unsafe.Pointer(dir)).l == (*darwinDir)(unsafe.Pointer(dir)).h {
  1541. n, err := unix.Getdirentries((*darwinDir)(unsafe.Pointer(dir)).fd, (*darwinDir)(unsafe.Pointer(dir)).buf[:], nil)
  1542. // trc("must read: %v %v", n, err)
  1543. if n == 0 {
  1544. if err != nil && err != io.EOF {
  1545. if dmesgs {
  1546. dmesg("%v: %v FAIL", origin(1), err)
  1547. }
  1548. t.setErrno(err)
  1549. }
  1550. (*darwinDir)(unsafe.Pointer(dir)).eof = true
  1551. return 0
  1552. }
  1553. (*darwinDir)(unsafe.Pointer(dir)).l = 0
  1554. (*darwinDir)(unsafe.Pointer(dir)).h = n
  1555. // trc("new l %v, h %v", (*darwinDir)(unsafe.Pointer(dir)).l, (*darwinDir)(unsafe.Pointer(dir)).h)
  1556. }
  1557. de := dir + unsafe.Offsetof(darwinDir{}.buf) + uintptr((*darwinDir)(unsafe.Pointer(dir)).l)
  1558. (*darwinDir)(unsafe.Pointer(dir)).l += int((*unix.Dirent)(unsafe.Pointer(de)).Reclen)
  1559. return de
  1560. }
  1561. type darwinDir struct {
  1562. buf [4096]byte
  1563. fd int
  1564. h int
  1565. l int
  1566. eof bool
  1567. }
  1568. // int sscanf(const char *str, const char *format, ...);
  1569. func Xsscanf(t *TLS, str, format, va uintptr) int32 {
  1570. if __ccgo_strace {
  1571. trc("t=%v va=%v, (%v:)", t, va, origin(2))
  1572. }
  1573. r := scanf(strings.NewReader(GoString(str)), format, va)
  1574. // if dmesgs {
  1575. // dmesg("%v: %q %q: %d", origin(1), GoString(str), GoString(format), r)
  1576. // }
  1577. return r
  1578. }
  1579. // int * __error(void);
  1580. func X__error(t *TLS) uintptr {
  1581. if __ccgo_strace {
  1582. trc("t=%v, (%v:)", t, origin(2))
  1583. }
  1584. return t.errnop
  1585. }
  1586. func Xclosedir(t *TLS, dir uintptr) int32 {
  1587. if __ccgo_strace {
  1588. trc("t=%v dir=%v, (%v:)", t, dir, origin(2))
  1589. }
  1590. r := Xclose(t, int32((*darwinDir)(unsafe.Pointer(dir)).fd))
  1591. Xfree(t, dir)
  1592. return r
  1593. }
  1594. // int __xuname(int namesize, void *namebuf)
  1595. func X__xuname(t *TLS, namesize int32, namebuf uintptr) int32 {
  1596. if __ccgo_strace {
  1597. trc("t=%v namesize=%v namebuf=%v, (%v:)", t, namesize, namebuf, origin(2))
  1598. }
  1599. return Xuname(t, namebuf)
  1600. }
  1601. // int chflags(const char *path, u_int flags);
  1602. func Xchflags(t *TLS, path uintptr, flags uint32) int32 {
  1603. if __ccgo_strace {
  1604. trc("t=%v path=%v flags=%v, (%v:)", t, path, flags, origin(2))
  1605. }
  1606. if err := unix.Chflags(GoString(path), int(flags)); err != nil {
  1607. if dmesgs {
  1608. dmesg("%v: %v FAIL", origin(1), err)
  1609. }
  1610. t.setErrno(err)
  1611. return -1
  1612. }
  1613. if dmesgs {
  1614. dmesg("%v: ok", origin(1))
  1615. }
  1616. return 0
  1617. }
  1618. // int pipe(int pipefd[2]);
  1619. func Xpipe(t *TLS, pipefd uintptr) int32 {
  1620. if __ccgo_strace {
  1621. trc("t=%v pipefd=%v, (%v:)", t, pipefd, origin(2))
  1622. }
  1623. var a [2]int
  1624. if err := unix.Pipe(a[:]); err != nil {
  1625. if dmesgs {
  1626. dmesg("%v: %v FAIL", origin(1), err)
  1627. }
  1628. t.setErrno(err)
  1629. return -1
  1630. }
  1631. *(*[2]int32)(unsafe.Pointer(pipefd)) = [2]int32{int32(a[0]), int32(a[1])}
  1632. if dmesgs {
  1633. dmesg("%v: %v ok", origin(1), a)
  1634. }
  1635. return 0
  1636. }
  1637. // char *inet_ntoa(struct in_addr in);
  1638. func X__inet_ntoa(t *TLS, in1 in.In_addr) uintptr {
  1639. if __ccgo_strace {
  1640. trc("t=%v in1=%v, (%v:)", t, in1, origin(2))
  1641. }
  1642. panic(todo(""))
  1643. }
  1644. func Xmmap(t *TLS, addr uintptr, length types.Size_t, prot, flags, fd int32, offset types.Off_t) uintptr {
  1645. if __ccgo_strace {
  1646. trc("t=%v addr=%v length=%v fd=%v offset=%v, (%v:)", t, addr, length, fd, offset, origin(2))
  1647. }
  1648. if addr == 0 {
  1649. data, err := unix.Mmap(int(fd), int64(offset), int(length), int(prot), int(flags))
  1650. if err != nil {
  1651. t.setErrno(err)
  1652. return ^uintptr(0)
  1653. }
  1654. if __ccgo_strace {
  1655. trc("Xmmap returning %v", uintptr(unsafe.Pointer(&data)))
  1656. }
  1657. return uintptr(unsafe.Pointer(&data[0]))
  1658. }
  1659. // On 2021-12-23, a new syscall for mmap was introduced:
  1660. //
  1661. // 49 STD NOLOCK { void *sys_mmap(void *addr, size_t len, int prot, \
  1662. // int flags, int fd, off_t pos); }
  1663. // src: https://github.com/golang/go/issues/59661
  1664. if __ccgo_strace {
  1665. trc("Xmmap with addr %d (%v:)", addr, origin(2))
  1666. }
  1667. panic(todo(""))
  1668. const unix_SYS_MMAP = 49
  1669. // Cannot avoid the syscall here, addr sometimes matter.
  1670. data, _, err := unix.RawSyscall6(unix_SYS_MMAP, addr, uintptr(length), uintptr(prot), uintptr(flags), uintptr(fd), uintptr(offset))
  1671. if err != 0 {
  1672. //if dmesgs {
  1673. dmesg("%v: %v FAIL", origin(1), err)
  1674. //}
  1675. t.setErrno(err)
  1676. return ^uintptr(0) // (void*)-1
  1677. }
  1678. if dmesgs {
  1679. dmesg("%v: addr %#0x, length %#x0, prot %#0x, flags %#0x, fd %d, offset %#0x returns %#0x", origin(1), addr, length, prot, flags, fd, offset, data)
  1680. }
  1681. return data
  1682. }
  1683. func X__errno(t *TLS) uintptr {
  1684. if __ccgo_strace {
  1685. trc("t=%v, (%v:)", t, origin(2))
  1686. }
  1687. return X__errno_location(t)
  1688. }
  1689. func X__ccgo_pthreadMutexattrGettype(tls *TLS, a uintptr) int32 { /* pthread_attr_get.c:93:5: */
  1690. if __ccgo_strace {
  1691. trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
  1692. }
  1693. return (int32((*pthread_mutexattr_t)(unsafe.Pointer(a)).F__attr & uint32(3)))
  1694. }
  1695. func X__ccgo_getMutexType(tls *TLS, m uintptr) int32 { /* pthread_mutex_lock.c:3:5: */
  1696. if __ccgo_strace {
  1697. trc("tls=%v m=%v, (%v:)", tls, m, origin(2))
  1698. }
  1699. return (*(*int32)(unsafe.Pointer((m /* &.__u */ /* &.__i */))) & 15)
  1700. }
  1701. func X__ccgo_pthreadAttrGetDetachState(tls *TLS, a uintptr) int32 { /* pthread_attr_get.c:3:5: */
  1702. if __ccgo_strace {
  1703. trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
  1704. }
  1705. return *(*int32)(unsafe.Pointer((a /* &.__u */ /* &.__i */) + 6*4))
  1706. }
  1707. func Xpthread_attr_getdetachstate(tls *TLS, a uintptr, state uintptr) int32 { /* pthread_attr_get.c:7:5: */
  1708. if __ccgo_strace {
  1709. trc("tls=%v a=%v state=%v, (%v:)", tls, a, state, origin(2))
  1710. }
  1711. *(*int32)(unsafe.Pointer(state)) = *(*int32)(unsafe.Pointer((a /* &.__u */ /* &.__i */) + 6*4))
  1712. return 0
  1713. }
  1714. func Xpthread_attr_setdetachstate(tls *TLS, a uintptr, state int32) int32 { /* pthread_attr_setdetachstate.c:3:5: */
  1715. if __ccgo_strace {
  1716. trc("tls=%v a=%v state=%v, (%v:)", tls, a, state, origin(2))
  1717. }
  1718. if uint32(state) > 1 {
  1719. return 22
  1720. }
  1721. *(*int32)(unsafe.Pointer((a /* &.__u */ /* &.__i */) + 6*4)) = state
  1722. return 0
  1723. }
  1724. func Xpthread_mutexattr_destroy(tls *TLS, a uintptr) int32 { /* pthread_mutexattr_destroy.c:3:5: */
  1725. if __ccgo_strace {
  1726. trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
  1727. }
  1728. return 0
  1729. }
  1730. func Xpthread_mutexattr_init(tls *TLS, a uintptr) int32 { /* pthread_mutexattr_init.c:3:5: */
  1731. if __ccgo_strace {
  1732. trc("tls=%v a=%v, (%v:)", tls, a, origin(2))
  1733. }
  1734. *(*pthread_mutexattr_t)(unsafe.Pointer(a)) = pthread_mutexattr_t{}
  1735. return 0
  1736. }
  1737. func Xpthread_mutexattr_settype(tls *TLS, a uintptr, type1 int32) int32 { /* pthread_mutexattr_settype.c:3:5: */
  1738. if __ccgo_strace {
  1739. trc("tls=%v a=%v type1=%v, (%v:)", tls, a, type1, origin(2))
  1740. }
  1741. if uint32(type1) > uint32(2) {
  1742. return 22
  1743. }
  1744. (*pthread_mutexattr_t)(unsafe.Pointer(a)).F__attr = (((*pthread_mutexattr_t)(unsafe.Pointer(a)).F__attr & Uint32FromInt32(CplInt32(3))) | uint32(type1))
  1745. return 0
  1746. }
  1747. // int uuid_parse( char *in, uuid_t uu);
  1748. func Xuuid_parse(t *TLS, in uintptr, uu uintptr) int32 {
  1749. if __ccgo_strace {
  1750. trc("t=%v in=%v uu=%v, (%v:)", t, in, uu, origin(2))
  1751. }
  1752. r, err := guuid.Parse(GoString(in))
  1753. if err != nil {
  1754. return -1
  1755. }
  1756. copy((*RawMem)(unsafe.Pointer(uu))[:unsafe.Sizeof(uuid.Uuid_t{})], r[:])
  1757. return 0
  1758. }
  1759. func X__srget(t *TLS, stream uintptr) int32 {
  1760. if __ccgo_strace {
  1761. trc("t=%v stream=%v, (%v:)", t, stream, origin(2))
  1762. }
  1763. return Xgetc(t, stream)
  1764. }
  1765. // void __assert2(const char *, int, const char *, const char *);
  1766. // __assert2(__FILE__, __LINE__, __func__, #e))
  1767. func X__assert2(t *TLS, file uintptr, line int32, fn, expr uintptr) {
  1768. if __ccgo_strace {
  1769. trc("t=%v file=%v line=%v expr=%v, (%v:)", t, file, line, expr, origin(2))
  1770. }
  1771. X__assert_fail(t, expr, file, uint32(line), fn)
  1772. }
  1773. // int getpagesize(void);
  1774. func Xgetpagesize(t *TLS) int32 {
  1775. if __ccgo_strace {
  1776. trc("t=%v, (%v:)", t, origin(2))
  1777. }
  1778. return int32(unix.Getpagesize())
  1779. }
  1780. const PTHREAD_MUTEX_DEFAULT = 0
  1781. // The pthread_mutex_init() function shall initialize the mutex referenced by
  1782. // mutex with attributes specified by attr. If attr is NULL, the default mutex
  1783. // attributes are used; the effect shall be the same as passing the address of
  1784. // a default mutex attributes object. Upon successful initialization, the state
  1785. // of the mutex becomes initialized and unlocked.
  1786. //
  1787. // If successful, the pthread_mutex_destroy() and pthread_mutex_init()
  1788. // functions shall return zero; otherwise, an error number shall be returned to
  1789. // indicate the error.
  1790. //
  1791. // int pthread_mutex_init(pthread_mutex_t *restrict mutex, const pthread_mutexattr_t *restrict attr);
  1792. func Xpthread_mutex_init(t *TLS, pMutex, pAttr uintptr) int32 {
  1793. if __ccgo_strace {
  1794. trc("t=%v pAttr=%v, (%v:)", t, pAttr, origin(2))
  1795. }
  1796. typ := PTHREAD_MUTEX_DEFAULT
  1797. if pAttr != 0 {
  1798. typ = int(X__ccgo_pthreadMutexattrGettype(t, pAttr))
  1799. }
  1800. mutexesMu.Lock()
  1801. defer mutexesMu.Unlock()
  1802. mutexes[pMutex] = newMutex(typ)
  1803. return 0
  1804. }
  1805. // uint16_t __builtin_bswap16 (uint32_t x)
  1806. func Xbswap16(t *TLS, x uint16) uint16 {
  1807. if __ccgo_strace {
  1808. trc("t=%v x=%v, (%v:)", t, x, origin(2))
  1809. }
  1810. return X__builtin_bswap16(t, x)
  1811. }
  1812. func X__swap16md(t *TLS, x uint16) uint16 {
  1813. if __ccgo_strace {
  1814. trc("t=%v x=%v, (%v:)", t, x, origin(2))
  1815. }
  1816. return X__builtin_bswap16(t, x)
  1817. }
  1818. // uint32_t __builtin_bswap32 (uint32_t x)
  1819. func Xbswap32(t *TLS, x uint32) uint32 {
  1820. if __ccgo_strace {
  1821. trc("t=%v x=%v, (%v:)", t, x, origin(2))
  1822. }
  1823. return X__builtin_bswap32(t, x)
  1824. }
  1825. // uint64_t __builtin_bswap64 (uint64_t x)
  1826. func Xbswap64(t *TLS, x uint64) uint64 {
  1827. if __ccgo_strace {
  1828. trc("t=%v x=%v, (%v:)", t, x, origin(2))
  1829. }
  1830. return X__builtin_bswap64(t, x)
  1831. }
  1832. func X__builtin_isblank(t *TLS, _c int32) int32 {
  1833. if __ccgo_strace {
  1834. trc("t=%v _c=%v, (%v:)", t, _c, origin(2))
  1835. }
  1836. return Xisblank(t, _c)
  1837. }
  1838. // int nanosleep(const struct timespec *req, struct timespec *rem);
  1839. func Xnanosleep(t *TLS, req, rem uintptr) int32 {
  1840. if __ccgo_strace {
  1841. trc("t=%v rem=%v, (%v:)", t, rem, origin(2))
  1842. }
  1843. v := *(*time.Timespec)(unsafe.Pointer(req))
  1844. gotime.Sleep(gotime.Second*gotime.Duration(v.Ftv_sec) + gotime.Duration(v.Ftv_nsec))
  1845. return 0
  1846. }
  1847. // ssize_t pwrite(int fd, const void *buf, size_t count, off_t offset);
  1848. func Xpwrite(t *TLS, fd int32, buf uintptr, count types.Size_t, offset types.Off_t) types.Ssize_t {
  1849. if __ccgo_strace {
  1850. trc("t=%v fd=%v buf=%v count=%v offset=%v, (%v:)", t, fd, buf, count, offset, origin(2))
  1851. }
  1852. var n int
  1853. var err error
  1854. switch {
  1855. case count == 0:
  1856. n, err = unix.Pwrite(int(fd), nil, int64(offset))
  1857. default:
  1858. n, err = unix.Pwrite(int(fd), (*RawMem)(unsafe.Pointer(buf))[:count:count], int64(offset))
  1859. // if dmesgs {
  1860. // dmesg("%v: fd %v, off %#x, count %#x\n%s", origin(1), fd, offset, count, hex.Dump((*RawMem)(unsafe.Pointer(buf))[:count:count]))
  1861. // }
  1862. }
  1863. if err != nil {
  1864. // if dmesgs {
  1865. // dmesg("%v: %v FAIL", origin(1), err)
  1866. // }
  1867. t.setErrno(err)
  1868. return -1
  1869. }
  1870. // if dmesgs {
  1871. // dmesg("%v: ok", origin(1))
  1872. // }
  1873. return types.Ssize_t(n)
  1874. }
  1875. // int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);
  1876. func Xsigaction(t *TLS, signum int32, act, oldact uintptr) int32 {
  1877. if __ccgo_strace {
  1878. trc("t=%v signum=%v oldact=%v, (%v:)", t, signum, oldact, origin(2))
  1879. }
  1880. panic(todo("SYS_SIGACTION not supported"))
  1881. }
  1882. // FILE *fopen64(const char *pathname, const char *mode);
  1883. func Xfopen64(t *TLS, pathname, mode uintptr) uintptr {
  1884. if __ccgo_strace {
  1885. trc("t=%v mode=%v, (%v:)", t, mode, origin(2))
  1886. }
  1887. m := strings.ReplaceAll(GoString(mode), "b", "")
  1888. var flags int
  1889. switch m {
  1890. case "r":
  1891. flags = fcntl.O_RDONLY
  1892. case "r+":
  1893. flags = fcntl.O_RDWR
  1894. case "w":
  1895. flags = fcntl.O_WRONLY | fcntl.O_CREAT | fcntl.O_TRUNC
  1896. case "w+":
  1897. flags = fcntl.O_RDWR | fcntl.O_CREAT | fcntl.O_TRUNC
  1898. case "a":
  1899. flags = fcntl.O_WRONLY | fcntl.O_CREAT | fcntl.O_APPEND
  1900. case "a+":
  1901. flags = fcntl.O_RDWR | fcntl.O_CREAT | fcntl.O_APPEND
  1902. default:
  1903. panic(m)
  1904. }
  1905. fd, err := unix.Open(GoString(pathname), int(flags), 0666)
  1906. if err != nil {
  1907. if dmesgs {
  1908. dmesg("%v: %q %q: %v FAIL", origin(1), GoString(pathname), GoString(mode), err)
  1909. }
  1910. t.setErrno(err)
  1911. return 0
  1912. }
  1913. if dmesgs {
  1914. dmesg("%v: %q %q: fd %v", origin(1), GoString(pathname), GoString(mode), fd)
  1915. }
  1916. if p := newFile(t, int32(fd)); p != 0 {
  1917. return p
  1918. }
  1919. panic("OOM")
  1920. }
  1921. // int lstat(const char *pathname, struct stat *statbuf);
  1922. func Xlstat64(t *TLS, pathname, statbuf uintptr) int32 {
  1923. if __ccgo_strace {
  1924. trc("t=%v pathname=%s statbuf=%v, (%v:)", t, GoString(pathname), statbuf, origin(2))
  1925. }
  1926. if err := unix.Lstat(GoString(pathname), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  1927. if dmesgs {
  1928. dmesg("%v: %q: %v FAIL", origin(1), GoString(pathname), err)
  1929. }
  1930. t.setErrno(err)
  1931. return -1
  1932. }
  1933. if dmesgs {
  1934. dmesg("%v: %q: ok", origin(1), GoString(pathname))
  1935. }
  1936. return 0
  1937. }
  1938. // int stat(const char *pathname, struct stat *statbuf);
  1939. func Xstat64(t *TLS, pathname, statbuf uintptr) int32 {
  1940. if __ccgo_strace {
  1941. trc("t=%v pathname=%s statbuf=%v, (%v:)", t, GoString(pathname), statbuf, origin(2))
  1942. }
  1943. if err := unix.Stat(GoString(pathname), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  1944. if dmesgs {
  1945. dmesg("%v: %q: %v FAIL", origin(1), GoString(pathname), err)
  1946. }
  1947. t.setErrno(err)
  1948. return -1
  1949. }
  1950. if dmesgs {
  1951. dmesg("%v: %q: ok", origin(1), GoString(pathname))
  1952. }
  1953. return 0
  1954. }
  1955. // int mkdir(const char *path, mode_t mode);
  1956. func Xmkdir(t *TLS, path uintptr, mode types.Mode_t) int32 {
  1957. if __ccgo_strace {
  1958. trc("t=%v path=%v mode=%v, (%v:)", t, GoString(path), mode, origin(2))
  1959. }
  1960. if err := unix.Mkdir(GoString(path), uint32(mode)); err != nil {
  1961. if dmesgs {
  1962. dmesg("%v: %q: %v FAIL", origin(1), GoString(path), err)
  1963. }
  1964. t.setErrno(err)
  1965. return -1
  1966. }
  1967. if dmesgs {
  1968. dmesg("%v: %q: ok", origin(1), GoString(path))
  1969. }
  1970. return 0
  1971. }
  1972. // int access(const char *pathname, int mode);
  1973. func Xaccess(t *TLS, pathname uintptr, mode int32) int32 {
  1974. if __ccgo_strace {
  1975. trc("t=%v pathname=%v mode=%v, (%v:)", t, GoString(pathname), mode, origin(2))
  1976. }
  1977. if err := unix.Access(GoString(pathname), uint32(mode)); err != nil {
  1978. if dmesgs {
  1979. dmesg("%v: %q %#o: %v FAIL", origin(1), GoString(pathname), mode, err)
  1980. }
  1981. t.setErrno(err)
  1982. return -1
  1983. }
  1984. if dmesgs {
  1985. dmesg("%v: %q %#o: ok", origin(1), GoString(pathname), mode)
  1986. }
  1987. return 0
  1988. }
  1989. // int unlink(const char *pathname);
  1990. func Xunlink(t *TLS, pathname uintptr) int32 {
  1991. if __ccgo_strace {
  1992. trc("t=%v pathname=%v, (%v:)", t, GoString(pathname), origin(2))
  1993. }
  1994. if err := unix.Unlink(GoString(pathname)); err != nil {
  1995. if dmesgs {
  1996. dmesg("%v: %q: %v", origin(1), GoString(pathname), err)
  1997. }
  1998. t.setErrno(err)
  1999. return -1
  2000. }
  2001. if dmesgs {
  2002. dmesg("%v: ok", origin(1))
  2003. }
  2004. return 0
  2005. }
  2006. // ssize_t readlink(const char *restrict path, char *restrict buf, size_t bufsize);
  2007. func Xreadlink(t *TLS, path, buf uintptr, bufsize types.Size_t) types.Ssize_t {
  2008. if __ccgo_strace {
  2009. trc("t=%v buf=%v bufsize=%v, (%v:)", t, buf, bufsize, origin(2))
  2010. }
  2011. var n int
  2012. var err error
  2013. switch {
  2014. case buf == 0 || bufsize == 0:
  2015. n, err = unix.Readlink(GoString(path), nil)
  2016. default:
  2017. n, err = unix.Readlink(GoString(path), (*RawMem)(unsafe.Pointer(buf))[:bufsize:bufsize])
  2018. }
  2019. if err != nil {
  2020. if dmesgs {
  2021. dmesg("%v: %v FAIL", err)
  2022. }
  2023. t.setErrno(err)
  2024. return -1
  2025. }
  2026. if dmesgs {
  2027. dmesg("%v: ok")
  2028. }
  2029. return types.Ssize_t(n)
  2030. }
  2031. // int symlink(const char *target, const char *linkpath);
  2032. func Xsymlink(t *TLS, target, linkpath uintptr) int32 {
  2033. if __ccgo_strace {
  2034. trc("t=%v linkpath=%v, (%v:)", t, GoString(linkpath), origin(2))
  2035. }
  2036. if err := unix.Symlink(GoString(target), GoString(linkpath)); err != nil {
  2037. if dmesgs {
  2038. dmesg("%v: %v FAIL", origin(1), err)
  2039. }
  2040. t.setErrno(err)
  2041. return -1
  2042. }
  2043. if dmesgs {
  2044. dmesg("%v: ok", origin(1))
  2045. }
  2046. return 0
  2047. }
  2048. // int chmod(const char *pathname, mode_t mode)
  2049. func Xchmod(t *TLS, pathname uintptr, mode types.Mode_t) int32 {
  2050. if __ccgo_strace {
  2051. trc("t=%v pathname=%v mode=%v, (%v:)", t, GoString(pathname), mode, origin(2))
  2052. }
  2053. if err := unix.Chmod(GoString(pathname), uint32(mode)); err != nil {
  2054. if dmesgs {
  2055. dmesg("%v: %q %#o: %v FAIL", origin(1), GoString(pathname), mode, err)
  2056. }
  2057. t.setErrno(err)
  2058. return -1
  2059. }
  2060. if dmesgs {
  2061. dmesg("%v: %q %#o: ok", origin(1), GoString(pathname), mode)
  2062. }
  2063. return 0
  2064. }
  2065. // time_t time(time_t *tloc);
  2066. func Xtime(t *TLS, tloc uintptr) time.Time_t {
  2067. if __ccgo_strace {
  2068. trc("t=%v tloc=%v, (%v:)", t, tloc, origin(2))
  2069. }
  2070. panic(todo(""))
  2071. // n := time.Now().UTC().Unix()
  2072. // if tloc != 0 {
  2073. // *(*types.Time_t)(unsafe.Pointer(tloc)) = types.Time_t(n)
  2074. // }
  2075. // return types.Time_t(n)
  2076. }
  2077. // int utimes(const char *filename, const struct timeval times[2]);
  2078. func Xutimes(t *TLS, filename, times uintptr) int32 {
  2079. if __ccgo_strace {
  2080. trc("t=%v filename=%v, times=%v, (%v:)", t, GoString(filename), times, origin(2))
  2081. }
  2082. var a []unix.Timeval
  2083. if times != 0 {
  2084. a = make([]unix.Timeval, 2)
  2085. a[0] = *(*unix.Timeval)(unsafe.Pointer(times))
  2086. a[1] = *(*unix.Timeval)(unsafe.Pointer(times + unsafe.Sizeof(unix.Timeval{})))
  2087. }
  2088. if err := unix.Utimes(GoString(filename), a); err != nil {
  2089. if dmesgs {
  2090. dmesg("%v: %v FAIL", origin(1), err)
  2091. }
  2092. t.setErrno(err)
  2093. return -1
  2094. }
  2095. if dmesgs {
  2096. dmesg("%v: ok", origin(1))
  2097. }
  2098. return 0
  2099. }
  2100. // int fstat(int fd, struct stat *statbuf);
  2101. func Xfstat64(t *TLS, fd int32, statbuf uintptr) int32 {
  2102. if __ccgo_strace {
  2103. trc("t=%v fd=%v statbuf=%v, (%v:)", t, fd, *(*unix.Stat_t)(unsafe.Pointer(statbuf)), origin(2))
  2104. }
  2105. if err := unix.Fstat(int(fd), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  2106. if dmesgs {
  2107. dmesg("%v: fd %d: %v FAIL", origin(1), fd, err)
  2108. }
  2109. t.setErrno(err)
  2110. return -1
  2111. }
  2112. if dmesgs {
  2113. dmesg("%v: fd %d: ok", origin(1), fd)
  2114. }
  2115. return 0
  2116. }
  2117. // off64_t lseek64(int fd, off64_t offset, int whence);
  2118. func Xlseek64(t *TLS, fd int32, offset types.Off_t, whence int32) types.Off_t {
  2119. if __ccgo_strace {
  2120. trc("t=%v fd=%v offset=%v whence=%v, (%v:)", t, fd, offset, whence, origin(2))
  2121. }
  2122. n, err := unix.Seek(int(fd), int64(offset), int(whence))
  2123. if err != nil {
  2124. if dmesgs {
  2125. dmesg("%v: %v FAIL", origin(1), err)
  2126. }
  2127. t.setErrno(err)
  2128. return -1
  2129. }
  2130. if dmesgs {
  2131. dmesg("%v: fd %d, offset %#0x, whence %d, ok", origin(1), fd, offset, whence)
  2132. }
  2133. return types.Off_t(n)
  2134. }
  2135. // int fcntl(int fd, int cmd, ... /* arg */ );
  2136. func Xfcntl64(t *TLS, fd, cmd int32, args uintptr) (r int32) {
  2137. if __ccgo_strace {
  2138. trc("t=%v cmd=%v args=%v, (%v:)", t, cmd, args, origin(2))
  2139. defer func() { trc("-> %v", r) }()
  2140. }
  2141. var err error
  2142. var p uintptr
  2143. var i int
  2144. switch cmd {
  2145. case fcntl.F_GETLK, fcntl.F_SETLK:
  2146. p = *(*uintptr)(unsafe.Pointer(args))
  2147. err = unix.FcntlFlock(uintptr(fd), int(cmd), (*unix.Flock_t)(unsafe.Pointer(p)))
  2148. case fcntl.F_GETFL:
  2149. i, err = unix.FcntlInt(uintptr(fd), int(cmd), 0)
  2150. r = int32(i)
  2151. case fcntl.F_SETFD, fcntl.F_SETFL:
  2152. arg := *(*int32)(unsafe.Pointer(args))
  2153. _, err = unix.FcntlInt(uintptr(fd), int(cmd), int(arg))
  2154. default:
  2155. panic(todo("%v: %v %v", origin(1), fd, cmd))
  2156. }
  2157. if err != nil {
  2158. if dmesgs {
  2159. dmesg("%v: fd %v cmd %v p %#x: %v FAIL", origin(1), fcntlCmdStr(fd), cmd, p, err)
  2160. }
  2161. t.setErrno(err)
  2162. return -1
  2163. }
  2164. if dmesgs {
  2165. dmesg("%v: %d %s %#x: ok", origin(1), fd, fcntlCmdStr(cmd), p)
  2166. }
  2167. return r
  2168. }
  2169. // int rename(const char *oldpath, const char *newpath);
  2170. func Xrename(t *TLS, oldpath, newpath uintptr) int32 {
  2171. if __ccgo_strace {
  2172. trc("t=%v newpath=%v, (%v:)", t, newpath, origin(2))
  2173. }
  2174. if err := unix.Rename(GoString(oldpath), GoString(newpath)); err != nil {
  2175. if dmesgs {
  2176. dmesg("%v: %v FAIL", origin(1), err)
  2177. }
  2178. t.setErrno(err)
  2179. return -1
  2180. }
  2181. if dmesgs {
  2182. dmesg("%v: ok", origin(1))
  2183. }
  2184. return 0
  2185. }
  2186. // int mknod(const char *pathname, mode_t mode, dev_t dev);
  2187. func Xmknod(t *TLS, pathname uintptr, mode types.Mode_t, dev types.Dev_t) int32 {
  2188. if __ccgo_strace {
  2189. trc("t=%v pathname=%v mode=%v dev=%v, (%v:)", t, pathname, mode, dev, origin(2))
  2190. }
  2191. if err := unix.Mknod(GoString(pathname), uint32(mode), int(dev)); err != nil {
  2192. t.setErrno(err)
  2193. return -1
  2194. }
  2195. return 0
  2196. }
  2197. // int utime(const char *filename, const struct utimbuf *times);
  2198. func Xutime(t *TLS, filename, times uintptr) int32 {
  2199. if __ccgo_strace {
  2200. trc("t=%v times=%v, (%v:)", t, times, origin(2))
  2201. }
  2202. var a []unix.Timeval
  2203. if times != 0 {
  2204. a = make([]unix.Timeval, 2)
  2205. a[0].Sec = (*utime.Utimbuf)(unsafe.Pointer(times)).Factime
  2206. a[1].Sec = (*utime.Utimbuf)(unsafe.Pointer(times)).Fmodtime
  2207. }
  2208. if err := unix.Utimes(GoString(filename), a); err != nil {
  2209. if dmesgs {
  2210. dmesg("%v: %v FAIL", origin(1), err)
  2211. }
  2212. t.setErrno(err)
  2213. return -1
  2214. }
  2215. if dmesgs {
  2216. dmesg("%v: ok", origin(1))
  2217. }
  2218. return 0
  2219. }
  2220. // int chown(const char *pathname, uid_t owner, gid_t group);
  2221. func Xchown(t *TLS, pathname uintptr, owner types.Uid_t, group types.Gid_t) int32 {
  2222. if __ccgo_strace {
  2223. trc("t=%v pathname=%v owner=%v group=%v, (%v:)", t, pathname, owner, group, origin(2))
  2224. }
  2225. if err := unix.Chown(GoString(pathname), int(owner), int(group)); err != nil {
  2226. t.setErrno(err)
  2227. return -1
  2228. }
  2229. return 0
  2230. }
  2231. // int link(const char *oldpath, const char *newpath);
  2232. func Xlink(t *TLS, oldpath, newpath uintptr) int32 {
  2233. if __ccgo_strace {
  2234. trc("t=%v newpath=%v, (%v:)", t, newpath, origin(2))
  2235. }
  2236. if err := unix.Link(GoString(oldpath), GoString(newpath)); err != nil {
  2237. t.setErrno(err)
  2238. return -1
  2239. }
  2240. return 0
  2241. }
  2242. // int dup2(int oldfd, int newfd);
  2243. func Xdup2(t *TLS, oldfd, newfd int32) int32 {
  2244. if __ccgo_strace {
  2245. trc("t=%v newfd=%v, (%v:)", t, newfd, origin(2))
  2246. }
  2247. if err := unix.Dup2(int(oldfd), int(newfd)); err != nil {
  2248. t.setErrno(err)
  2249. return -1
  2250. }
  2251. return 0
  2252. }
  2253. // unsigned int alarm(unsigned int seconds);
  2254. func Xalarm(t *TLS, seconds uint32) uint32 {
  2255. if __ccgo_strace {
  2256. trc("t=%v seconds=%v, (%v:)", t, seconds, origin(2))
  2257. }
  2258. panic("SYS_ALARM not supported")
  2259. /* n, err := unix.Alarm(uint(seconds))
  2260. if err != nil {
  2261. t.setErrno(err)
  2262. return 0
  2263. }
  2264. return uint32(n)
  2265. */
  2266. }
  2267. // int getnameinfo(const struct sockaddr * restrict sa, socklen_t salen, char * restrict host, socklen_t hostlen, char * restrict serv, socklen_t servlen, int flags);
  2268. func Xgetnameinfo(tls *TLS, sa1 uintptr, sl socklen_t, node uintptr, nodelen size_t, serv uintptr, servlen size_t, flags int32) int32 { /* getnameinfo.c:125:5: */
  2269. if __ccgo_strace {
  2270. trc("tls=%v sa1=%v sl=%v node=%v nodelen=%v serv=%v servlen=%v flags=%v, (%v:)", tls, sa1, sl, node, nodelen, serv, servlen, flags, origin(2))
  2271. }
  2272. panic(todo(""))
  2273. //TODO bp := tls.Alloc(347)
  2274. //TODO defer tls.Free(347)
  2275. //TODO // var ptr [78]int8 at bp, 78
  2276. //TODO // var buf [256]int8 at bp+78, 256
  2277. //TODO // var num [13]int8 at bp+334, 13
  2278. //TODO var af int32 = int32((*sockaddr)(unsafe.Pointer(sa1)).sa_family)
  2279. //TODO var a uintptr
  2280. //TODO var scopeid uint32
  2281. //TODO switch af {
  2282. //TODO case 2:
  2283. //TODO a = (sa1 + 4 /* &.sin_addr */)
  2284. //TODO if (uint64(sl) < uint64(unsafe.Sizeof(sockaddr_in{}))) {
  2285. //TODO return -6
  2286. //TODO }
  2287. //TODO mkptr4(tls, bp /* &ptr[0] */, a)
  2288. //TODO scopeid = uint32(0)
  2289. //TODO break
  2290. //TODO case 10:
  2291. //TODO a = (sa1 + 8 /* &.sin6_addr */)
  2292. //TODO if (uint64(sl) < uint64(unsafe.Sizeof(sockaddr_in6{}))) {
  2293. //TODO return -6
  2294. //TODO }
  2295. //TODO if Xmemcmp(tls, a, ts+88 /* "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xff\xff" */, uint64(12)) != 0 {
  2296. //TODO mkptr6(tls, bp /* &ptr[0] */, a)
  2297. //TODO } else {
  2298. //TODO mkptr4(tls, bp /* &ptr[0] */, (a + uintptr(12)))
  2299. //TODO }
  2300. //TODO scopeid = (*sockaddr_in6)(unsafe.Pointer(sa1)).sin6_scope_id
  2301. //TODO break
  2302. //TODO default:
  2303. //TODO return -6
  2304. //TODO }
  2305. //TODO if (node != 0) && (nodelen != 0) {
  2306. //TODO *(*int8)(unsafe.Pointer(bp + 78 /* &buf[0] */)) = int8(0)
  2307. //TODO if !((flags & 0x01) != 0) {
  2308. //TODO reverse_hosts(tls, bp+78 /* &buf[0] */, a, scopeid, af)
  2309. //TODO }
  2310. //TODO if !(int32(*(*int8)(unsafe.Pointer(bp + 78 /* buf */))) != 0) && !((flags & 0x01) != 0) {
  2311. //TODO Xabort(tls) //TODO-
  2312. //TODO // unsigned char query[18+PTR_MAX], reply[512];
  2313. //TODO // int qlen = __res_mkquery(0, ptr, 1, RR_PTR,
  2314. //TODO // 0, 0, 0, query, sizeof query);
  2315. //TODO // query[3] = 0; /* don't need AD flag */
  2316. //TODO // int rlen = __res_send(query, qlen, reply, sizeof reply);
  2317. //TODO // buf[0] = 0;
  2318. //TODO // if (rlen > 0)
  2319. //TODO // __dns_parse(reply, rlen, dns_parse_callback, buf);
  2320. //TODO }
  2321. //TODO if !(int32(*(*int8)(unsafe.Pointer(bp + 78 /* buf */))) != 0) {
  2322. //TODO if (flags & 0x08) != 0 {
  2323. //TODO return -2
  2324. //TODO }
  2325. //TODO Xinet_ntop(tls, af, a, bp+78 /* &buf[0] */, uint32(unsafe.Sizeof([256]int8{})))
  2326. //TODO if scopeid != 0 {
  2327. //TODO Xabort(tls) //TODO-
  2328. //TODO // char *p = 0, tmp[IF_NAMESIZE+1];
  2329. //TODO // if (!(flags & NI_NUMERICSCOPE) &&
  2330. //TODO // (IN6_IS_ADDR_LINKLOCAL(a) ||
  2331. //TODO // IN6_IS_ADDR_MC_LINKLOCAL(a)))
  2332. //TODO // p = if_indextoname(scopeid, tmp+1);
  2333. //TODO // if (!p)
  2334. //TODO // p = itoa(num, scopeid);
  2335. //TODO // *--p = '%';
  2336. //TODO // strcat(buf, p);
  2337. //TODO }
  2338. //TODO }
  2339. //TODO if Xstrlen(tls, bp+78 /* &buf[0] */) >= size_t(nodelen) {
  2340. //TODO return -12
  2341. //TODO }
  2342. //TODO Xstrcpy(tls, node, bp+78 /* &buf[0] */)
  2343. //TODO }
  2344. //TODO if (serv != 0) && (servlen != 0) {
  2345. //TODO var p uintptr = bp + 78 /* buf */
  2346. //TODO var port int32 = int32(Xntohs(tls, (*sockaddr_in)(unsafe.Pointer(sa1)).sin_port))
  2347. //TODO *(*int8)(unsafe.Pointer(bp + 78 /* &buf[0] */)) = int8(0)
  2348. //TODO if !((flags & 0x02) != 0) {
  2349. //TODO reverse_services(tls, bp+78 /* &buf[0] */, port, (flags & 0x10))
  2350. //TODO }
  2351. //TODO if !(int32(*(*int8)(unsafe.Pointer(p))) != 0) {
  2352. //TODO p = itoa(tls, bp+334 /* &num[0] */, uint32(port))
  2353. //TODO }
  2354. //TODO if Xstrlen(tls, p) >= size_t(servlen) {
  2355. //TODO return -12
  2356. //TODO }
  2357. //TODO Xstrcpy(tls, serv, p)
  2358. //TODO }
  2359. //TODO return 0
  2360. }
  2361. func Xgethostbyaddr_r(tls *TLS, a uintptr, l socklen_t, af int32, h uintptr, buf uintptr, buflen size_t, res uintptr, err uintptr) int32 { /* gethostbyaddr_r.c:10:5: */
  2362. if __ccgo_strace {
  2363. trc("tls=%v a=%v l=%v af=%v h=%v buf=%v buflen=%v res=%v err=%v, (%v:)", tls, a, l, af, h, buf, buflen, res, err, origin(2))
  2364. }
  2365. panic(todo(""))
  2366. //TODO bp := tls.Alloc(28)
  2367. //TODO defer tls.Free(28)
  2368. //TODO //TODO union {
  2369. //TODO //TODO struct sockaddr_in sin;
  2370. //TODO //TODO struct sockaddr_in6 sin6;
  2371. //TODO //TODO } sa = { .sin.sin_family = af };
  2372. //TODO *(*struct {
  2373. //TODO sin sockaddr_in
  2374. //TODO _ [12]byte
  2375. //TODO })(unsafe.Pointer(bp /* sa1 */)) = struct {
  2376. //TODO sin sockaddr_in
  2377. //TODO _ [12]byte
  2378. //TODO }{} //TODO-
  2379. //TODO (*sockaddr_in)(unsafe.Pointer(bp /* &sa1 */)).sin_family = sa_family_t(af) //TODO-
  2380. //TODO var sl socklen_t
  2381. //TODO if af == 10 {
  2382. //TODO sl = uint32(unsafe.Sizeof(sockaddr_in6{}))
  2383. //TODO } else {
  2384. //TODO sl = uint32(unsafe.Sizeof(sockaddr_in{}))
  2385. //TODO }
  2386. //TODO var i int32
  2387. //TODO *(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
  2388. //TODO // Load address argument into sockaddr structure
  2389. //TODO if (af == 10) && (l == socklen_t(16)) {
  2390. //TODO Xmemcpy(tls, (bp /* &sa1 */ /* &.sin6 */ + 8 /* &.sin6_addr */), a, uint64(16))
  2391. //TODO } else if (af == 2) && (l == socklen_t(4)) {
  2392. //TODO Xmemcpy(tls, (bp /* &sa1 */ /* &.sin */ + 4 /* &.sin_addr */), a, uint64(4))
  2393. //TODO } else {
  2394. //TODO *(*int32)(unsafe.Pointer(err)) = 3
  2395. //TODO return 22
  2396. //TODO }
  2397. //TODO // Align buffer and check for space for pointers and ip address
  2398. //TODO i = (int32(uintptr_t(buf) & (uint64(unsafe.Sizeof(uintptr(0))) - uint64(1))))
  2399. //TODO if !(i != 0) {
  2400. //TODO i = int32(unsafe.Sizeof(uintptr(0)))
  2401. //TODO }
  2402. //TODO if buflen <= (((uint64(5) * uint64(unsafe.Sizeof(uintptr(0)))) - uint64(i)) + uint64(l)) {
  2403. //TODO return 34
  2404. //TODO }
  2405. //TODO buf += (uintptr(uint64(unsafe.Sizeof(uintptr(0))) - uint64(i)))
  2406. //TODO buflen = buflen - (((uint64(5) * uint64(unsafe.Sizeof(uintptr(0)))) - uint64(i)) + uint64(l))
  2407. //TODO (*hostent)(unsafe.Pointer(h)).h_addr_list = buf
  2408. //TODO buf += (uintptr(uint64(2) * uint64(unsafe.Sizeof(uintptr(0)))))
  2409. //TODO (*hostent)(unsafe.Pointer(h)).h_aliases = buf
  2410. //TODO buf += (uintptr(uint64(2) * uint64(unsafe.Sizeof(uintptr(0)))))
  2411. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list)) = buf
  2412. //TODO Xmemcpy(tls, *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list)), a, uint64(l))
  2413. //TODO buf += uintptr(l)
  2414. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list + 1*8)) = uintptr(0)
  2415. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases)) = buf
  2416. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases + 1*8)) = uintptr(0)
  2417. //TODO switch Xgetnameinfo(tls, bp /* &sa1 */, sl, buf, uint32(buflen), uintptr(0), uint32(0), 0) {
  2418. //TODO case -3:
  2419. //TODO *(*int32)(unsafe.Pointer(err)) = 2
  2420. //TODO return 11
  2421. //TODO case -12:
  2422. //TODO return 34
  2423. //TODO default:
  2424. //TODO fallthrough
  2425. //TODO case -10:
  2426. //TODO fallthrough
  2427. //TODO case -11:
  2428. //TODO fallthrough
  2429. //TODO case -4:
  2430. //TODO *(*int32)(unsafe.Pointer(err)) = 3
  2431. //TODO return *(*int32)(unsafe.Pointer(X___errno_location(tls)))
  2432. //TODO case 0:
  2433. //TODO break
  2434. //TODO }
  2435. //TODO (*hostent)(unsafe.Pointer(h)).h_addrtype = af
  2436. //TODO (*hostent)(unsafe.Pointer(h)).h_length = int32(l)
  2437. //TODO (*hostent)(unsafe.Pointer(h)).h_name = *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases))
  2438. //TODO *(*uintptr)(unsafe.Pointer(res)) = h
  2439. //TODO return 0
  2440. }
  2441. // int getrlimit(int resource, struct rlimit *rlim);
  2442. func Xgetrlimit64(t *TLS, resource int32, rlim uintptr) int32 {
  2443. if __ccgo_strace {
  2444. trc("t=%v resource=%v rlim=%v, (%v:)", t, resource, rlim, origin(2))
  2445. }
  2446. if err := unix.Getrlimit(int(resource), (*unix.Rlimit)(unsafe.Pointer(rlim))); err != nil {
  2447. t.setErrno(err)
  2448. return -1
  2449. }
  2450. return 0
  2451. }
  2452. func newFtsent(t *TLS, info int, path string, stat *unix.Stat_t, err syscallErrno) (r *fts.FTSENT) {
  2453. var statp uintptr
  2454. if stat != nil {
  2455. statp = Xmalloc(t, types.Size_t(unsafe.Sizeof(unix.Stat_t{})))
  2456. if statp == 0 {
  2457. panic("OOM")
  2458. }
  2459. *(*unix.Stat_t)(unsafe.Pointer(statp)) = *stat
  2460. }
  2461. csp, errx := CString(path)
  2462. if errx != nil {
  2463. panic("OOM")
  2464. }
  2465. return &fts.FTSENT{
  2466. Ffts_info: uint16(info),
  2467. Ffts_path: csp,
  2468. Ffts_pathlen: types.Size_t(len(path)),
  2469. Ffts_statp: statp,
  2470. Ffts_errno: int32(err),
  2471. }
  2472. }
  2473. // DIR *opendir(const char *name);
  2474. func Xopendir(t *TLS, name uintptr) uintptr {
  2475. if __ccgo_strace {
  2476. trc("t=%v name=%v, (%v:)", t, name, origin(2))
  2477. }
  2478. p := Xmalloc(t, types.Size_t(unsafe.Sizeof(darwinDir{})))
  2479. if p == 0 {
  2480. panic("OOM")
  2481. }
  2482. fd := int(Xopen(t, name, fcntl.O_RDONLY|fcntl.O_DIRECTORY|fcntl.O_CLOEXEC, 0))
  2483. if fd < 0 {
  2484. if dmesgs {
  2485. dmesg("%v: FAIL %v", origin(1), (*darwinDir)(unsafe.Pointer(p)).fd)
  2486. }
  2487. Xfree(t, p)
  2488. return 0
  2489. }
  2490. if dmesgs {
  2491. dmesg("%v: ok", origin(1))
  2492. }
  2493. (*darwinDir)(unsafe.Pointer(p)).fd = fd
  2494. (*darwinDir)(unsafe.Pointer(p)).h = 0
  2495. (*darwinDir)(unsafe.Pointer(p)).l = 0
  2496. (*darwinDir)(unsafe.Pointer(p)).eof = false
  2497. return p
  2498. }
  2499. func Xrewinddir(tls *TLS, f uintptr) {
  2500. if __ccgo_strace {
  2501. trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
  2502. }
  2503. Xfseek(tls, f, 0, stdio.SEEK_SET)
  2504. }
  2505. // clock_t clock(void);
  2506. func Xclock(t *TLS) time.Clock_t {
  2507. if __ccgo_strace {
  2508. trc("t=%v, (%v:)", t, origin(2))
  2509. }
  2510. return time.Clock_t(gotime.Since(startTime) * gotime.Duration(time.CLOCKS_PER_SEC) / gotime.Second)
  2511. }
  2512. // ssize_t recvmsg(int sockfd, struct msghdr *msg, int flags);
  2513. func Xrecvmsg(t *TLS, sockfd int32, msg uintptr, flags int32) types.Ssize_t {
  2514. if __ccgo_strace {
  2515. trc("t=%v sockfd=%v msg=%v flags=%v, (%v:)", t, sockfd, msg, flags, origin(2))
  2516. }
  2517. oob := []byte{}
  2518. buf := []byte{}
  2519. n, _, _, _, err := unix.Recvmsg(int(sockfd), buf, oob, int(flags))
  2520. if err != nil {
  2521. t.setErrno(err)
  2522. return -1
  2523. }
  2524. copy((*RawMem)(unsafe.Pointer(msg))[:n:n], buf[:])
  2525. return types.Ssize_t(n)
  2526. }