libc_freebsd_amd64.go 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956
  1. // Copyright 2021 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. "strings"
  7. gotime "time"
  8. "unsafe"
  9. "golang.org/x/sys/unix"
  10. "modernc.org/libc/fcntl"
  11. "modernc.org/libc/fts"
  12. "modernc.org/libc/stdio"
  13. "modernc.org/libc/sys/types"
  14. "modernc.org/libc/time"
  15. "modernc.org/libc/utime"
  16. )
  17. type (
  18. long = int64
  19. ulong = uint64
  20. )
  21. var (
  22. startTime = gotime.Now() // For clock(3)
  23. )
  24. // int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);
  25. func Xsigaction(t *TLS, signum int32, act, oldact uintptr) int32 {
  26. if __ccgo_strace {
  27. trc("t=%v signum=%v oldact=%v, (%v:)", t, signum, oldact, origin(2))
  28. }
  29. if _, _, err := unix.Syscall(unix.SYS_SIGACTION, uintptr(signum), act, oldact); err != 0 {
  30. t.setErrno(err)
  31. return -1
  32. }
  33. return 0
  34. }
  35. // FILE *fopen64(const char *pathname, const char *mode);
  36. func Xfopen64(t *TLS, pathname, mode uintptr) uintptr {
  37. if __ccgo_strace {
  38. trc("t=%v mode=%v, (%v:)", t, mode, origin(2))
  39. }
  40. m := strings.ReplaceAll(GoString(mode), "b", "")
  41. var flags int
  42. switch m {
  43. case "r":
  44. flags = fcntl.O_RDONLY
  45. case "r+":
  46. flags = fcntl.O_RDWR
  47. case "w":
  48. flags = fcntl.O_WRONLY | fcntl.O_CREAT | fcntl.O_TRUNC
  49. case "w+":
  50. flags = fcntl.O_RDWR | fcntl.O_CREAT | fcntl.O_TRUNC
  51. case "a":
  52. flags = fcntl.O_WRONLY | fcntl.O_CREAT | fcntl.O_APPEND
  53. case "a+":
  54. flags = fcntl.O_RDWR | fcntl.O_CREAT | fcntl.O_APPEND
  55. default:
  56. panic(m)
  57. }
  58. fd, err := unix.Open(GoString(pathname), int(flags), 0666)
  59. if err != nil {
  60. if dmesgs {
  61. dmesg("%v: %q %q: %v FAIL", origin(1), GoString(pathname), GoString(mode), err)
  62. }
  63. t.setErrno(err)
  64. return 0
  65. }
  66. if dmesgs {
  67. dmesg("%v: %q %q: fd %v", origin(1), GoString(pathname), GoString(mode), fd)
  68. }
  69. if p := newFile(t, int32(fd)); p != 0 {
  70. return p
  71. }
  72. panic("OOM")
  73. }
  74. // int lstat(const char *pathname, struct stat *statbuf);
  75. func Xlstat64(t *TLS, pathname, statbuf uintptr) int32 {
  76. if __ccgo_strace {
  77. trc("t=%v statbuf=%v, (%v:)", t, statbuf, origin(2))
  78. }
  79. if err := unix.Lstat(GoString(pathname), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  80. if dmesgs {
  81. dmesg("%v: %q: %v FAIL", origin(1), GoString(pathname), err)
  82. }
  83. t.setErrno(err)
  84. return -1
  85. }
  86. if dmesgs {
  87. dmesg("%v: %q: ok", origin(1), GoString(pathname))
  88. }
  89. return 0
  90. }
  91. // int stat(const char *pathname, struct stat *statbuf);
  92. func Xstat64(t *TLS, pathname, statbuf uintptr) int32 {
  93. if __ccgo_strace {
  94. trc("t=%v statbuf=%v, (%v:)", t, statbuf, origin(2))
  95. }
  96. if err := unix.Stat(GoString(pathname), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  97. if dmesgs {
  98. dmesg("%v: %q: %v FAIL", origin(1), GoString(pathname), err)
  99. }
  100. t.setErrno(err)
  101. return -1
  102. }
  103. if dmesgs {
  104. dmesg("%v: %q: ok", origin(1), GoString(pathname))
  105. }
  106. return 0
  107. }
  108. // int mkdir(const char *path, mode_t mode);
  109. func Xmkdir(t *TLS, path uintptr, mode types.Mode_t) int32 {
  110. if __ccgo_strace {
  111. trc("t=%v path=%v mode=%v, (%v:)", t, path, mode, origin(2))
  112. }
  113. if err := unix.Mkdir(GoString(path), uint32(mode)); err != nil {
  114. if dmesgs {
  115. dmesg("%v: %q: %v FAIL", origin(1), GoString(path), err)
  116. }
  117. t.setErrno(err)
  118. return -1
  119. }
  120. if dmesgs {
  121. dmesg("%v: %q: ok", origin(1), GoString(path))
  122. }
  123. return 0
  124. }
  125. // int access(const char *pathname, int mode);
  126. func Xaccess(t *TLS, pathname uintptr, mode int32) int32 {
  127. if __ccgo_strace {
  128. trc("t=%v pathname=%v mode=%v, (%v:)", t, pathname, mode, origin(2))
  129. }
  130. if err := unix.Access(GoString(pathname), uint32(mode)); err != nil {
  131. if dmesgs {
  132. dmesg("%v: %q %#o: %v FAIL", origin(1), GoString(pathname), mode, err)
  133. }
  134. t.setErrno(err)
  135. return -1
  136. }
  137. if dmesgs {
  138. dmesg("%v: %q %#o: ok", origin(1), GoString(pathname), mode)
  139. }
  140. return 0
  141. }
  142. // int unlink(const char *pathname);
  143. func Xunlink(t *TLS, pathname uintptr) int32 {
  144. if __ccgo_strace {
  145. trc("t=%v pathname=%v, (%v:)", t, pathname, origin(2))
  146. }
  147. if err := unix.Unlink(GoString(pathname)); err != nil {
  148. if dmesgs {
  149. dmesg("%v: %q: %v", origin(1), GoString(pathname), err)
  150. }
  151. t.setErrno(err)
  152. return -1
  153. }
  154. if dmesgs {
  155. dmesg("%v: ok", origin(1))
  156. }
  157. return 0
  158. }
  159. // ssize_t readlink(const char *restrict path, char *restrict buf, size_t bufsize);
  160. func Xreadlink(t *TLS, path, buf uintptr, bufsize types.Size_t) types.Ssize_t {
  161. if __ccgo_strace {
  162. trc("t=%v buf=%v bufsize=%v, (%v:)", t, buf, bufsize, origin(2))
  163. }
  164. var n int
  165. var err error
  166. switch {
  167. case buf == 0 || bufsize == 0:
  168. n, err = unix.Readlink(GoString(path), nil)
  169. default:
  170. n, err = unix.Readlink(GoString(path), (*RawMem)(unsafe.Pointer(buf))[:bufsize:bufsize])
  171. }
  172. if err != nil {
  173. if dmesgs {
  174. dmesg("%v: %v FAIL", err)
  175. }
  176. t.setErrno(err)
  177. return -1
  178. }
  179. if dmesgs {
  180. dmesg("%v: ok")
  181. }
  182. return types.Ssize_t(n)
  183. }
  184. // int symlink(const char *target, const char *linkpath);
  185. func Xsymlink(t *TLS, target, linkpath uintptr) int32 {
  186. if __ccgo_strace {
  187. trc("t=%v linkpath=%v, (%v:)", t, linkpath, origin(2))
  188. }
  189. if err := unix.Symlink(GoString(target), GoString(linkpath)); err != nil {
  190. if dmesgs {
  191. dmesg("%v: %v FAIL", origin(1), err)
  192. }
  193. t.setErrno(err)
  194. return -1
  195. }
  196. if dmesgs {
  197. dmesg("%v: ok", origin(1))
  198. }
  199. return 0
  200. }
  201. // int chmod(const char *pathname, mode_t mode)
  202. func Xchmod(t *TLS, pathname uintptr, mode types.Mode_t) int32 {
  203. if __ccgo_strace {
  204. trc("t=%v pathname=%v mode=%v, (%v:)", t, pathname, mode, origin(2))
  205. }
  206. if err := unix.Chmod(GoString(pathname), uint32(mode)); err != nil {
  207. if dmesgs {
  208. dmesg("%v: %q %#o: %v FAIL", origin(1), GoString(pathname), mode, err)
  209. }
  210. t.setErrno(err)
  211. return -1
  212. }
  213. if dmesgs {
  214. dmesg("%v: %q %#o: ok", origin(1), GoString(pathname), mode)
  215. }
  216. return 0
  217. }
  218. // time_t time(time_t *tloc);
  219. func Xtime(t *TLS, tloc uintptr) time.Time_t {
  220. if __ccgo_strace {
  221. trc("t=%v tloc=%v, (%v:)", t, tloc, origin(2))
  222. }
  223. panic(todo(""))
  224. // n := time.Now().UTC().Unix()
  225. // if tloc != 0 {
  226. // *(*types.Time_t)(unsafe.Pointer(tloc)) = types.Time_t(n)
  227. // }
  228. // return types.Time_t(n)
  229. }
  230. // int utimes(const char *filename, const struct timeval times[2]);
  231. func Xutimes(t *TLS, filename, times uintptr) int32 {
  232. if __ccgo_strace {
  233. trc("t=%v times=%v, (%v:)", t, times, origin(2))
  234. }
  235. var a []unix.Timeval
  236. if times != 0 {
  237. a = make([]unix.Timeval, 2)
  238. a[0] = *(*unix.Timeval)(unsafe.Pointer(times))
  239. a[1] = *(*unix.Timeval)(unsafe.Pointer(times + unsafe.Sizeof(unix.Timeval{})))
  240. }
  241. if err := unix.Utimes(GoString(filename), a); err != nil {
  242. if dmesgs {
  243. dmesg("%v: %v FAIL", origin(1), err)
  244. }
  245. t.setErrno(err)
  246. return -1
  247. }
  248. if dmesgs {
  249. dmesg("%v: ok", origin(1))
  250. }
  251. return 0
  252. }
  253. // int fstat(int fd, struct stat *statbuf);
  254. func Xfstat64(t *TLS, fd int32, statbuf uintptr) int32 {
  255. if __ccgo_strace {
  256. trc("t=%v fd=%v statbuf=%v, (%v:)", t, fd, statbuf, origin(2))
  257. }
  258. if err := unix.Fstat(int(fd), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  259. if dmesgs {
  260. dmesg("%v: fd %d: %v FAIL", origin(1), fd, err)
  261. }
  262. t.setErrno(err)
  263. return -1
  264. }
  265. if dmesgs {
  266. dmesg("%v: fd %d: ok", origin(1), fd)
  267. }
  268. return 0
  269. }
  270. // off64_t lseek64(int fd, off64_t offset, int whence);
  271. func Xlseek64(t *TLS, fd int32, offset types.Off_t, whence int32) types.Off_t {
  272. if __ccgo_strace {
  273. trc("t=%v fd=%v offset=%v whence=%v, (%v:)", t, fd, offset, whence, origin(2))
  274. }
  275. n, err := unix.Seek(int(fd), int64(offset), int(whence))
  276. if err != nil {
  277. if dmesgs {
  278. dmesg("%v: %v FAIL", origin(1), err)
  279. }
  280. t.setErrno(err)
  281. return -1
  282. }
  283. if dmesgs {
  284. dmesg("%v: ok", origin(1))
  285. }
  286. return types.Off_t(n)
  287. }
  288. func Xfcntl64(t *TLS, fd, cmd int32, args uintptr) int32 {
  289. if __ccgo_strace {
  290. trc("t=%v cmd=%v args=%v, (%v:)", t, cmd, args, origin(2))
  291. }
  292. var arg uintptr
  293. if args != 0 {
  294. arg = *(*uintptr)(unsafe.Pointer(args))
  295. }
  296. n, _, err := unix.Syscall(unix.SYS_FCNTL, uintptr(fd), uintptr(cmd), arg)
  297. if err != 0 {
  298. if dmesgs {
  299. dmesg("%v: fd %v cmd %v", origin(1), fcntlCmdStr(fd), cmd)
  300. }
  301. t.setErrno(err)
  302. return -1
  303. }
  304. if dmesgs {
  305. dmesg("%v: %d %s %#x: %d", origin(1), fd, fcntlCmdStr(cmd), arg, n)
  306. }
  307. return int32(n)
  308. }
  309. // int rename(const char *oldpath, const char *newpath);
  310. func Xrename(t *TLS, oldpath, newpath uintptr) int32 {
  311. if __ccgo_strace {
  312. trc("t=%v newpath=%v, (%v:)", t, newpath, origin(2))
  313. }
  314. if err := unix.Rename(GoString(oldpath), GoString(newpath)); err != nil {
  315. if dmesgs {
  316. dmesg("%v: %v FAIL", origin(1), err)
  317. }
  318. t.setErrno(err)
  319. return -1
  320. }
  321. if dmesgs {
  322. dmesg("%v: ok", origin(1))
  323. }
  324. return 0
  325. }
  326. // int mknod(const char *pathname, mode_t mode, dev_t dev);
  327. func Xmknod(t *TLS, pathname uintptr, mode types.Mode_t, dev types.Dev_t) int32 {
  328. if __ccgo_strace {
  329. trc("t=%v pathname=%v mode=%v dev=%v, (%v:)", t, pathname, mode, dev, origin(2))
  330. }
  331. panic(todo(""))
  332. // if _, _, err := unix.Syscall(unix.SYS_MKNOD, pathname, uintptr(mode), uintptr(dev)); err != 0 {
  333. // t.setErrno(err)
  334. // return -1
  335. // }
  336. // return 0
  337. }
  338. // int utime(const char *filename, const struct utimbuf *times);
  339. func Xutime(t *TLS, filename, times uintptr) int32 {
  340. if __ccgo_strace {
  341. trc("t=%v times=%v, (%v:)", t, times, origin(2))
  342. }
  343. var a []unix.Timeval
  344. if times != 0 {
  345. a = make([]unix.Timeval, 2)
  346. a[0].Sec = (*utime.Utimbuf)(unsafe.Pointer(times)).Factime
  347. a[1].Sec = (*utime.Utimbuf)(unsafe.Pointer(times)).Fmodtime
  348. }
  349. if err := unix.Utimes(GoString(filename), a); err != nil {
  350. if dmesgs {
  351. dmesg("%v: %v FAIL", origin(1), err)
  352. }
  353. t.setErrno(err)
  354. return -1
  355. }
  356. if dmesgs {
  357. dmesg("%v: ok", origin(1))
  358. }
  359. return 0
  360. }
  361. // int chown(const char *pathname, uid_t owner, gid_t group);
  362. func Xchown(t *TLS, pathname uintptr, owner types.Uid_t, group types.Gid_t) int32 {
  363. if __ccgo_strace {
  364. trc("t=%v pathname=%v owner=%v group=%v, (%v:)", t, pathname, owner, group, origin(2))
  365. }
  366. if _, _, err := unix.Syscall(unix.SYS_CHOWN, pathname, uintptr(owner), uintptr(group)); err != 0 {
  367. t.setErrno(err)
  368. return -1
  369. }
  370. return 0
  371. }
  372. // int link(const char *oldpath, const char *newpath);
  373. func Xlink(t *TLS, oldpath, newpath uintptr) int32 {
  374. if __ccgo_strace {
  375. trc("t=%v newpath=%v, (%v:)", t, newpath, origin(2))
  376. }
  377. panic(todo(""))
  378. // if _, _, err := unix.Syscall(unix.SYS_LINK, oldpath, newpath, 0); err != 0 {
  379. // t.setErrno(err)
  380. // return -1
  381. // }
  382. // return 0
  383. }
  384. // int dup2(int oldfd, int newfd);
  385. func Xdup2(t *TLS, oldfd, newfd int32) int32 {
  386. if __ccgo_strace {
  387. trc("t=%v newfd=%v, (%v:)", t, newfd, origin(2))
  388. }
  389. panic(todo(""))
  390. // n, _, err := unix.Syscall(unix.SYS_DUP2, uintptr(oldfd), uintptr(newfd), 0)
  391. // if err != 0 {
  392. // t.setErrno(err)
  393. // return -1
  394. // }
  395. // return int32(n)
  396. }
  397. // unsigned int alarm(unsigned int seconds);
  398. func Xalarm(t *TLS, seconds uint32) uint32 {
  399. if __ccgo_strace {
  400. trc("t=%v seconds=%v, (%v:)", t, seconds, origin(2))
  401. }
  402. panic(todo(""))
  403. // n, _, err := unix.Syscall(unix.SYS_ALARM, uintptr(seconds), 0, 0)
  404. // if err != 0 {
  405. // panic(todo(""))
  406. // }
  407. // return uint32(n)
  408. }
  409. 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: */
  410. if __ccgo_strace {
  411. 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))
  412. }
  413. panic(todo(""))
  414. //TODO bp := tls.Alloc(347)
  415. //TODO defer tls.Free(347)
  416. //TODO // var ptr [78]int8 at bp, 78
  417. //TODO // var buf [256]int8 at bp+78, 256
  418. //TODO // var num [13]int8 at bp+334, 13
  419. //TODO var af int32 = int32((*sockaddr)(unsafe.Pointer(sa1)).sa_family)
  420. //TODO var a uintptr
  421. //TODO var scopeid uint32
  422. //TODO switch af {
  423. //TODO case 2:
  424. //TODO a = (sa1 + 4 /* &.sin_addr */)
  425. //TODO if (uint64(sl) < uint64(unsafe.Sizeof(sockaddr_in{}))) {
  426. //TODO return -6
  427. //TODO }
  428. //TODO mkptr4(tls, bp /* &ptr[0] */, a)
  429. //TODO scopeid = uint32(0)
  430. //TODO break
  431. //TODO case 10:
  432. //TODO a = (sa1 + 8 /* &.sin6_addr */)
  433. //TODO if (uint64(sl) < uint64(unsafe.Sizeof(sockaddr_in6{}))) {
  434. //TODO return -6
  435. //TODO }
  436. //TODO if Xmemcmp(tls, a, ts+88 /* "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xff\xff" */, uint64(12)) != 0 {
  437. //TODO mkptr6(tls, bp /* &ptr[0] */, a)
  438. //TODO } else {
  439. //TODO mkptr4(tls, bp /* &ptr[0] */, (a + uintptr(12)))
  440. //TODO }
  441. //TODO scopeid = (*sockaddr_in6)(unsafe.Pointer(sa1)).sin6_scope_id
  442. //TODO break
  443. //TODO default:
  444. //TODO return -6
  445. //TODO }
  446. //TODO if (node != 0) && (nodelen != 0) {
  447. //TODO *(*int8)(unsafe.Pointer(bp + 78 /* &buf[0] */)) = int8(0)
  448. //TODO if !((flags & 0x01) != 0) {
  449. //TODO reverse_hosts(tls, bp+78 /* &buf[0] */, a, scopeid, af)
  450. //TODO }
  451. //TODO if !(int32(*(*int8)(unsafe.Pointer(bp + 78 /* buf */))) != 0) && !((flags & 0x01) != 0) {
  452. //TODO Xabort(tls) //TODO-
  453. //TODO // unsigned char query[18+PTR_MAX], reply[512];
  454. //TODO // int qlen = __res_mkquery(0, ptr, 1, RR_PTR,
  455. //TODO // 0, 0, 0, query, sizeof query);
  456. //TODO // query[3] = 0; /* don't need AD flag */
  457. //TODO // int rlen = __res_send(query, qlen, reply, sizeof reply);
  458. //TODO // buf[0] = 0;
  459. //TODO // if (rlen > 0)
  460. //TODO // __dns_parse(reply, rlen, dns_parse_callback, buf);
  461. //TODO }
  462. //TODO if !(int32(*(*int8)(unsafe.Pointer(bp + 78 /* buf */))) != 0) {
  463. //TODO if (flags & 0x08) != 0 {
  464. //TODO return -2
  465. //TODO }
  466. //TODO Xinet_ntop(tls, af, a, bp+78 /* &buf[0] */, uint32(unsafe.Sizeof([256]int8{})))
  467. //TODO if scopeid != 0 {
  468. //TODO Xabort(tls) //TODO-
  469. //TODO // char *p = 0, tmp[IF_NAMESIZE+1];
  470. //TODO // if (!(flags & NI_NUMERICSCOPE) &&
  471. //TODO // (IN6_IS_ADDR_LINKLOCAL(a) ||
  472. //TODO // IN6_IS_ADDR_MC_LINKLOCAL(a)))
  473. //TODO // p = if_indextoname(scopeid, tmp+1);
  474. //TODO // if (!p)
  475. //TODO // p = itoa(num, scopeid);
  476. //TODO // *--p = '%';
  477. //TODO // strcat(buf, p);
  478. //TODO }
  479. //TODO }
  480. //TODO if Xstrlen(tls, bp+78 /* &buf[0] */) >= size_t(nodelen) {
  481. //TODO return -12
  482. //TODO }
  483. //TODO Xstrcpy(tls, node, bp+78 /* &buf[0] */)
  484. //TODO }
  485. //TODO if (serv != 0) && (servlen != 0) {
  486. //TODO var p uintptr = bp + 78 /* buf */
  487. //TODO var port int32 = int32(Xntohs(tls, (*sockaddr_in)(unsafe.Pointer(sa1)).sin_port))
  488. //TODO *(*int8)(unsafe.Pointer(bp + 78 /* &buf[0] */)) = int8(0)
  489. //TODO if !((flags & 0x02) != 0) {
  490. //TODO reverse_services(tls, bp+78 /* &buf[0] */, port, (flags & 0x10))
  491. //TODO }
  492. //TODO if !(int32(*(*int8)(unsafe.Pointer(p))) != 0) {
  493. //TODO p = itoa(tls, bp+334 /* &num[0] */, uint32(port))
  494. //TODO }
  495. //TODO if Xstrlen(tls, p) >= size_t(servlen) {
  496. //TODO return -12
  497. //TODO }
  498. //TODO Xstrcpy(tls, serv, p)
  499. //TODO }
  500. //TODO return 0
  501. }
  502. 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: */
  503. if __ccgo_strace {
  504. 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))
  505. }
  506. panic(todo(""))
  507. //TODO bp := tls.Alloc(28)
  508. //TODO defer tls.Free(28)
  509. //TODO //TODO union {
  510. //TODO //TODO struct sockaddr_in sin;
  511. //TODO //TODO struct sockaddr_in6 sin6;
  512. //TODO //TODO } sa = { .sin.sin_family = af };
  513. //TODO *(*struct {
  514. //TODO sin sockaddr_in
  515. //TODO _ [12]byte
  516. //TODO })(unsafe.Pointer(bp /* sa1 */)) = struct {
  517. //TODO sin sockaddr_in
  518. //TODO _ [12]byte
  519. //TODO }{} //TODO-
  520. //TODO (*sockaddr_in)(unsafe.Pointer(bp /* &sa1 */)).sin_family = sa_family_t(af) //TODO-
  521. //TODO var sl socklen_t
  522. //TODO if af == 10 {
  523. //TODO sl = uint32(unsafe.Sizeof(sockaddr_in6{}))
  524. //TODO } else {
  525. //TODO sl = uint32(unsafe.Sizeof(sockaddr_in{}))
  526. //TODO }
  527. //TODO var i int32
  528. //TODO *(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
  529. //TODO // Load address argument into sockaddr structure
  530. //TODO if (af == 10) && (l == socklen_t(16)) {
  531. //TODO Xmemcpy(tls, (bp /* &sa1 */ /* &.sin6 */ + 8 /* &.sin6_addr */), a, uint64(16))
  532. //TODO } else if (af == 2) && (l == socklen_t(4)) {
  533. //TODO Xmemcpy(tls, (bp /* &sa1 */ /* &.sin */ + 4 /* &.sin_addr */), a, uint64(4))
  534. //TODO } else {
  535. //TODO *(*int32)(unsafe.Pointer(err)) = 3
  536. //TODO return 22
  537. //TODO }
  538. //TODO // Align buffer and check for space for pointers and ip address
  539. //TODO i = (int32(uintptr_t(buf) & (uint64(unsafe.Sizeof(uintptr(0))) - uint64(1))))
  540. //TODO if !(i != 0) {
  541. //TODO i = int32(unsafe.Sizeof(uintptr(0)))
  542. //TODO }
  543. //TODO if buflen <= (((uint64(5) * uint64(unsafe.Sizeof(uintptr(0)))) - uint64(i)) + uint64(l)) {
  544. //TODO return 34
  545. //TODO }
  546. //TODO buf += (uintptr(uint64(unsafe.Sizeof(uintptr(0))) - uint64(i)))
  547. //TODO buflen = buflen - (((uint64(5) * uint64(unsafe.Sizeof(uintptr(0)))) - uint64(i)) + uint64(l))
  548. //TODO (*hostent)(unsafe.Pointer(h)).h_addr_list = buf
  549. //TODO buf += (uintptr(uint64(2) * uint64(unsafe.Sizeof(uintptr(0)))))
  550. //TODO (*hostent)(unsafe.Pointer(h)).h_aliases = buf
  551. //TODO buf += (uintptr(uint64(2) * uint64(unsafe.Sizeof(uintptr(0)))))
  552. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list)) = buf
  553. //TODO Xmemcpy(tls, *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list)), a, uint64(l))
  554. //TODO buf += uintptr(l)
  555. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list + 1*8)) = uintptr(0)
  556. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases)) = buf
  557. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases + 1*8)) = uintptr(0)
  558. //TODO switch Xgetnameinfo(tls, bp /* &sa1 */, sl, buf, uint32(buflen), uintptr(0), uint32(0), 0) {
  559. //TODO case -3:
  560. //TODO *(*int32)(unsafe.Pointer(err)) = 2
  561. //TODO return 11
  562. //TODO case -12:
  563. //TODO return 34
  564. //TODO default:
  565. //TODO fallthrough
  566. //TODO case -10:
  567. //TODO fallthrough
  568. //TODO case -11:
  569. //TODO fallthrough
  570. //TODO case -4:
  571. //TODO *(*int32)(unsafe.Pointer(err)) = 3
  572. //TODO return *(*int32)(unsafe.Pointer(X___errno_location(tls)))
  573. //TODO case 0:
  574. //TODO break
  575. //TODO }
  576. //TODO (*hostent)(unsafe.Pointer(h)).h_addrtype = af
  577. //TODO (*hostent)(unsafe.Pointer(h)).h_length = int32(l)
  578. //TODO (*hostent)(unsafe.Pointer(h)).h_name = *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases))
  579. //TODO *(*uintptr)(unsafe.Pointer(res)) = h
  580. //TODO return 0
  581. }
  582. // int getrlimit(int resource, struct rlimit *rlim);
  583. func Xgetrlimit64(t *TLS, resource int32, rlim uintptr) int32 {
  584. if __ccgo_strace {
  585. trc("t=%v resource=%v rlim=%v, (%v:)", t, resource, rlim, origin(2))
  586. }
  587. if _, _, err := unix.Syscall(unix.SYS_GETRLIMIT, uintptr(resource), uintptr(rlim), 0); err != 0 {
  588. t.setErrno(err)
  589. return -1
  590. }
  591. return 0
  592. }
  593. func newFtsent(t *TLS, info int, path string, stat *unix.Stat_t, err syscallErrno) (r *fts.FTSENT) {
  594. var statp uintptr
  595. if stat != nil {
  596. statp = Xmalloc(t, types.Size_t(unsafe.Sizeof(unix.Stat_t{})))
  597. if statp == 0 {
  598. panic("OOM")
  599. }
  600. *(*unix.Stat_t)(unsafe.Pointer(statp)) = *stat
  601. }
  602. csp, errx := CString(path)
  603. if errx != nil {
  604. panic("OOM")
  605. }
  606. return &fts.FTSENT{
  607. Ffts_info: int32(info),
  608. Ffts_path: csp,
  609. Ffts_pathlen: uint64(len(path)),
  610. Ffts_statp: statp,
  611. Ffts_errno: int32(err),
  612. }
  613. }
  614. // DIR *opendir(const char *name);
  615. func Xopendir(t *TLS, name uintptr) uintptr {
  616. if __ccgo_strace {
  617. trc("t=%v name=%v, (%v:)", t, name, origin(2))
  618. }
  619. p := Xmalloc(t, uint64(unsafe.Sizeof(darwinDir{})))
  620. if p == 0 {
  621. panic("OOM")
  622. }
  623. fd := int(Xopen(t, name, fcntl.O_RDONLY|fcntl.O_DIRECTORY|fcntl.O_CLOEXEC, 0))
  624. if fd < 0 {
  625. if dmesgs {
  626. dmesg("%v: FAIL %v", origin(1), (*darwinDir)(unsafe.Pointer(p)).fd)
  627. }
  628. Xfree(t, p)
  629. return 0
  630. }
  631. if dmesgs {
  632. dmesg("%v: ok", origin(1))
  633. }
  634. (*darwinDir)(unsafe.Pointer(p)).fd = fd
  635. (*darwinDir)(unsafe.Pointer(p)).h = 0
  636. (*darwinDir)(unsafe.Pointer(p)).l = 0
  637. (*darwinDir)(unsafe.Pointer(p)).eof = false
  638. return p
  639. }
  640. // int chflags(const char *path, u_int flags);
  641. func Xchflags(t *TLS, path uintptr, flags uint64) int32 {
  642. if __ccgo_strace {
  643. trc("t=%v path=%v flags=%v, (%v:)", t, path, flags, origin(2))
  644. }
  645. if err := unix.Chflags(GoString(path), int(flags)); err != nil {
  646. if dmesgs {
  647. dmesg("%v: %v FAIL", origin(1), err)
  648. }
  649. t.setErrno(err)
  650. return -1
  651. }
  652. if dmesgs {
  653. dmesg("%v: ok", origin(1))
  654. }
  655. return 0
  656. }
  657. var _table1 = [384]int32{
  658. 129: int32(1),
  659. 130: int32(2),
  660. 131: int32(3),
  661. 132: int32(4),
  662. 133: int32(5),
  663. 134: int32(6),
  664. 135: int32(7),
  665. 136: int32(8),
  666. 137: int32(9),
  667. 138: int32(10),
  668. 139: int32(11),
  669. 140: int32(12),
  670. 141: int32(13),
  671. 142: int32(14),
  672. 143: int32(15),
  673. 144: int32(16),
  674. 145: int32(17),
  675. 146: int32(18),
  676. 147: int32(19),
  677. 148: int32(20),
  678. 149: int32(21),
  679. 150: int32(22),
  680. 151: int32(23),
  681. 152: int32(24),
  682. 153: int32(25),
  683. 154: int32(26),
  684. 155: int32(27),
  685. 156: int32(28),
  686. 157: int32(29),
  687. 158: int32(30),
  688. 159: int32(31),
  689. 160: int32(32),
  690. 161: int32(33),
  691. 162: int32(34),
  692. 163: int32(35),
  693. 164: int32(36),
  694. 165: int32(37),
  695. 166: int32(38),
  696. 167: int32(39),
  697. 168: int32(40),
  698. 169: int32(41),
  699. 170: int32(42),
  700. 171: int32(43),
  701. 172: int32(44),
  702. 173: int32(45),
  703. 174: int32(46),
  704. 175: int32(47),
  705. 176: int32(48),
  706. 177: int32(49),
  707. 178: int32(50),
  708. 179: int32(51),
  709. 180: int32(52),
  710. 181: int32(53),
  711. 182: int32(54),
  712. 183: int32(55),
  713. 184: int32(56),
  714. 185: int32(57),
  715. 186: int32(58),
  716. 187: int32(59),
  717. 188: int32(60),
  718. 189: int32(61),
  719. 190: int32(62),
  720. 191: int32(63),
  721. 192: int32(64),
  722. 193: int32('a'),
  723. 194: int32('b'),
  724. 195: int32('c'),
  725. 196: int32('d'),
  726. 197: int32('e'),
  727. 198: int32('f'),
  728. 199: int32('g'),
  729. 200: int32('h'),
  730. 201: int32('i'),
  731. 202: int32('j'),
  732. 203: int32('k'),
  733. 204: int32('l'),
  734. 205: int32('m'),
  735. 206: int32('n'),
  736. 207: int32('o'),
  737. 208: int32('p'),
  738. 209: int32('q'),
  739. 210: int32('r'),
  740. 211: int32('s'),
  741. 212: int32('t'),
  742. 213: int32('u'),
  743. 214: int32('v'),
  744. 215: int32('w'),
  745. 216: int32('x'),
  746. 217: int32('y'),
  747. 218: int32('z'),
  748. 219: int32(91),
  749. 220: int32(92),
  750. 221: int32(93),
  751. 222: int32(94),
  752. 223: int32(95),
  753. 224: int32(96),
  754. 225: int32('a'),
  755. 226: int32('b'),
  756. 227: int32('c'),
  757. 228: int32('d'),
  758. 229: int32('e'),
  759. 230: int32('f'),
  760. 231: int32('g'),
  761. 232: int32('h'),
  762. 233: int32('i'),
  763. 234: int32('j'),
  764. 235: int32('k'),
  765. 236: int32('l'),
  766. 237: int32('m'),
  767. 238: int32('n'),
  768. 239: int32('o'),
  769. 240: int32('p'),
  770. 241: int32('q'),
  771. 242: int32('r'),
  772. 243: int32('s'),
  773. 244: int32('t'),
  774. 245: int32('u'),
  775. 246: int32('v'),
  776. 247: int32('w'),
  777. 248: int32('x'),
  778. 249: int32('y'),
  779. 250: int32('z'),
  780. 251: int32(123),
  781. 252: int32(124),
  782. 253: int32(125),
  783. 254: int32(126),
  784. 255: int32(127),
  785. }
  786. var _ptable1 = uintptr(unsafe.Pointer(&_table1)) + uintptr(128)*4
  787. func X__ctype_tolower_loc(tls *TLS) (r uintptr) {
  788. if __ccgo_strace {
  789. trc("tls=%v, (%v:)", tls, origin(2))
  790. defer func() { trc("-> %v", r) }()
  791. }
  792. return uintptr(unsafe.Pointer(&_ptable1))
  793. }
  794. type Tin6_addr = struct {
  795. F__in6_union struct {
  796. F__s6_addr16 [0][8]uint16
  797. F__s6_addr32 [0][4]uint32
  798. F__s6_addr [16]uint8
  799. }
  800. }
  801. var Xin6addr_any = Tin6_addr{}
  802. func Xrewinddir(tls *TLS, f uintptr) {
  803. if __ccgo_strace {
  804. trc("tls=%v f=%v, (%v:)", tls, f, origin(2))
  805. }
  806. Xfseek(tls, f, 0, stdio.SEEK_SET)
  807. }
  808. // clock_t clock(void);
  809. func Xclock(t *TLS) time.Clock_t {
  810. if __ccgo_strace {
  811. trc("t=%v, (%v:)", t, origin(2))
  812. }
  813. return time.Clock_t(gotime.Since(startTime) * gotime.Duration(time.CLOCKS_PER_SEC) / gotime.Second)
  814. }
  815. func X__maskrune(tls *TLS, _c int32, _f uint64) int32 {
  816. return int32(uint32(int32(*(*uint32)(unsafe.Pointer(uintptr(unsafe.Pointer(&X_DefaultRuneLocale)) + 60 + uintptr(_c&0xff)*4)))) & uint32(_f))
  817. }
  818. // int fstatfs(int fd, struct statfs *buf);
  819. func Xfstatfs(t *TLS, fd int32, buf uintptr) int32 {
  820. if err := unix.Fstatfs(int(fd), (*unix.Statfs_t)(unsafe.Pointer(buf))); err != nil {
  821. if dmesgs {
  822. dmesg("%v: %v: %v FAIL", origin(1), fd, err)
  823. }
  824. t.setErrno(err)
  825. return -1
  826. }
  827. if dmesgs {
  828. dmesg("%v: %v: ok", origin(1), fd)
  829. }
  830. return 0
  831. }
  832. type lconv = struct {
  833. Fdecimal_point uintptr
  834. Fthousands_sep uintptr
  835. Fgrouping uintptr
  836. Fint_curr_symbol uintptr
  837. Fcurrency_symbol uintptr
  838. Fmon_decimal_point uintptr
  839. Fmon_thousands_sep uintptr
  840. Fmon_grouping uintptr
  841. Fpositive_sign uintptr
  842. Fnegative_sign uintptr
  843. Fint_frac_digits int8
  844. Ffrac_digits int8
  845. Fp_cs_precedes int8
  846. Fp_sep_by_space int8
  847. Fn_cs_precedes int8
  848. Fn_sep_by_space int8
  849. Fp_sign_posn int8
  850. Fn_sign_posn int8
  851. Fint_p_cs_precedes int8
  852. Fint_p_sep_by_space int8
  853. Fint_n_cs_precedes int8
  854. Fint_n_sep_by_space int8
  855. Fint_p_sign_posn int8
  856. Fint_n_sign_posn int8
  857. F__ccgo_pad1 [2]byte
  858. }
  859. var posix_lconv = lconv{Fdecimal_point: ts + 23, Fthousands_sep: ts + 13, Fgrouping: ts + 13, Fint_curr_symbol: ts + 13, Fcurrency_symbol: ts + 13, Fmon_decimal_point: ts + 13, Fmon_thousands_sep: ts + 13, Fmon_grouping: ts + 13, Fpositive_sign: ts + 13, Fnegative_sign: ts + 13, Fint_frac_digits: Int8FromInt32(255), Ffrac_digits: Int8FromInt32(255), Fp_cs_precedes: Int8FromInt32(255), Fp_sep_by_space: Int8FromInt32(255), Fn_cs_precedes: Int8FromInt32(255), Fn_sep_by_space: Int8FromInt32(255), Fp_sign_posn: Int8FromInt32(255), Fn_sign_posn: Int8FromInt32(255), Fint_p_cs_precedes: Int8FromInt32(255), Fint_p_sep_by_space: Int8FromInt32(255), Fint_n_cs_precedes: Int8FromInt32(255), Fint_n_sep_by_space: Int8FromInt32(255), Fint_p_sign_posn: Int8FromInt32(255), Fint_n_sign_posn: Int8FromInt32(255)} /* localeconv.c:4:27 */
  860. func Xlocaleconv(tls *TLS) uintptr { /* localeconv.c:31:14: */
  861. return uintptr(unsafe.Pointer(&posix_lconv))
  862. }
  863. func X__tolower(tls *TLS, c int32) int32 { /* table.c:1878:20: */
  864. return Xtolower(tls, c)
  865. }