libc_freebsd_arm.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647
  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. "syscall"
  8. "unsafe"
  9. "golang.org/x/sys/unix"
  10. "modernc.org/libc/fcntl"
  11. "modernc.org/libc/fts"
  12. "modernc.org/libc/sys/types"
  13. "modernc.org/libc/time"
  14. "modernc.org/libc/utime"
  15. )
  16. type (
  17. long = int32
  18. ulong = uint32
  19. )
  20. // int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact);
  21. func Xsigaction(t *TLS, signum int32, act, oldact uintptr) int32 {
  22. if _, _, err := unix.Syscall(unix.SYS_SIGACTION, uintptr(signum), act, oldact); err != 0 {
  23. t.setErrno(err)
  24. return -1
  25. }
  26. return 0
  27. }
  28. // FILE *fopen64(const char *pathname, const char *mode);
  29. func Xfopen64(t *TLS, pathname, mode uintptr) uintptr {
  30. m := strings.ReplaceAll(GoString(mode), "b", "")
  31. var flags int
  32. switch m {
  33. case "r":
  34. flags = fcntl.O_RDONLY
  35. case "r+":
  36. flags = fcntl.O_RDWR
  37. case "w":
  38. flags = fcntl.O_WRONLY | fcntl.O_CREAT | fcntl.O_TRUNC
  39. case "w+":
  40. flags = fcntl.O_RDWR | fcntl.O_CREAT | fcntl.O_TRUNC
  41. case "a":
  42. flags = fcntl.O_WRONLY | fcntl.O_CREAT | fcntl.O_APPEND
  43. case "a+":
  44. flags = fcntl.O_RDWR | fcntl.O_CREAT | fcntl.O_APPEND
  45. default:
  46. panic(m)
  47. }
  48. fd, err := unix.Open(GoString(pathname), int(flags), 0666)
  49. if err != nil {
  50. if dmesgs {
  51. dmesg("%v: %q %q: %v FAIL", origin(1), GoString(pathname), GoString(mode), err)
  52. }
  53. t.setErrno(err)
  54. return 0
  55. }
  56. if dmesgs {
  57. dmesg("%v: %q %q: fd %v", origin(1), GoString(pathname), GoString(mode), fd)
  58. }
  59. if p := newFile(t, int32(fd)); p != 0 {
  60. return p
  61. }
  62. panic("OOM")
  63. }
  64. // int lstat(const char *pathname, struct stat *statbuf);
  65. func Xlstat64(t *TLS, pathname, statbuf uintptr) int32 {
  66. if err := unix.Lstat(GoString(pathname), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  67. if dmesgs {
  68. dmesg("%v: %q: %v FAIL", origin(1), GoString(pathname), err)
  69. }
  70. t.setErrno(err)
  71. return -1
  72. }
  73. if dmesgs {
  74. dmesg("%v: %q: ok", origin(1), GoString(pathname))
  75. }
  76. return 0
  77. }
  78. // int stat(const char *pathname, struct stat *statbuf);
  79. func Xstat64(t *TLS, pathname, statbuf uintptr) int32 {
  80. if err := unix.Stat(GoString(pathname), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  81. if dmesgs {
  82. dmesg("%v: %q: %v FAIL", origin(1), GoString(pathname), err)
  83. }
  84. t.setErrno(err)
  85. return -1
  86. }
  87. if dmesgs {
  88. dmesg("%v: %q: ok", origin(1), GoString(pathname))
  89. }
  90. return 0
  91. }
  92. // int mkdir(const char *path, mode_t mode);
  93. func Xmkdir(t *TLS, path uintptr, mode types.Mode_t) int32 {
  94. if err := unix.Mkdir(GoString(path), uint32(mode)); err != nil {
  95. if dmesgs {
  96. dmesg("%v: %q: %v FAIL", origin(1), GoString(path), err)
  97. }
  98. t.setErrno(err)
  99. return -1
  100. }
  101. if dmesgs {
  102. dmesg("%v: %q: ok", origin(1), GoString(path))
  103. }
  104. return 0
  105. }
  106. // int access(const char *pathname, int mode);
  107. func Xaccess(t *TLS, pathname uintptr, mode int32) int32 {
  108. if err := unix.Access(GoString(pathname), uint32(mode)); err != nil {
  109. if dmesgs {
  110. dmesg("%v: %q %#o: %v FAIL", origin(1), GoString(pathname), mode, err)
  111. }
  112. t.setErrno(err)
  113. return -1
  114. }
  115. if dmesgs {
  116. dmesg("%v: %q %#o: ok", origin(1), GoString(pathname), mode)
  117. }
  118. return 0
  119. }
  120. // int unlink(const char *pathname);
  121. func Xunlink(t *TLS, pathname uintptr) int32 {
  122. if err := unix.Unlink(GoString(pathname)); err != nil {
  123. if dmesgs {
  124. dmesg("%v: %q: %v", origin(1), GoString(pathname), err)
  125. }
  126. t.setErrno(err)
  127. return -1
  128. }
  129. if dmesgs {
  130. dmesg("%v: ok", origin(1))
  131. }
  132. return 0
  133. }
  134. // ssize_t readlink(const char *restrict path, char *restrict buf, size_t bufsize);
  135. func Xreadlink(t *TLS, path, buf uintptr, bufsize types.Size_t) types.Ssize_t {
  136. var n int
  137. var err error
  138. switch {
  139. case buf == 0 || bufsize == 0:
  140. n, err = unix.Readlink(GoString(path), nil)
  141. default:
  142. n, err = unix.Readlink(GoString(path), (*RawMem)(unsafe.Pointer(buf))[:bufsize:bufsize])
  143. }
  144. if err != nil {
  145. if dmesgs {
  146. dmesg("%v: %v FAIL", err)
  147. }
  148. t.setErrno(err)
  149. return -1
  150. }
  151. if dmesgs {
  152. dmesg("%v: ok")
  153. }
  154. return types.Ssize_t(n)
  155. }
  156. // int symlink(const char *target, const char *linkpath);
  157. func Xsymlink(t *TLS, target, linkpath uintptr) int32 {
  158. if err := unix.Symlink(GoString(target), GoString(linkpath)); err != nil {
  159. if dmesgs {
  160. dmesg("%v: %v FAIL", origin(1), err)
  161. }
  162. t.setErrno(err)
  163. return -1
  164. }
  165. if dmesgs {
  166. dmesg("%v: ok", origin(1))
  167. }
  168. return 0
  169. }
  170. // int chmod(const char *pathname, mode_t mode)
  171. func Xchmod(t *TLS, pathname uintptr, mode types.Mode_t) int32 {
  172. if err := unix.Chmod(GoString(pathname), uint32(mode)); err != nil {
  173. if dmesgs {
  174. dmesg("%v: %q %#o: %v FAIL", origin(1), GoString(pathname), mode, err)
  175. }
  176. t.setErrno(err)
  177. return -1
  178. }
  179. if dmesgs {
  180. dmesg("%v: %q %#o: ok", origin(1), GoString(pathname), mode)
  181. }
  182. return 0
  183. }
  184. // time_t time(time_t *tloc);
  185. func Xtime(t *TLS, tloc uintptr) time.Time_t {
  186. panic(todo(""))
  187. // n := time.Now().UTC().Unix()
  188. // if tloc != 0 {
  189. // *(*types.Time_t)(unsafe.Pointer(tloc)) = types.Time_t(n)
  190. // }
  191. // return types.Time_t(n)
  192. }
  193. // int utimes(const char *filename, const struct timeval times[2]);
  194. func Xutimes(t *TLS, filename, times uintptr) int32 {
  195. var a []unix.Timeval
  196. if times != 0 {
  197. a = make([]unix.Timeval, 2)
  198. a[0] = *(*unix.Timeval)(unsafe.Pointer(times))
  199. a[1] = *(*unix.Timeval)(unsafe.Pointer(times + unsafe.Sizeof(unix.Timeval{})))
  200. }
  201. if err := unix.Utimes(GoString(filename), a); err != nil {
  202. if dmesgs {
  203. dmesg("%v: %v FAIL", origin(1), err)
  204. }
  205. t.setErrno(err)
  206. return -1
  207. }
  208. if dmesgs {
  209. dmesg("%v: ok", origin(1))
  210. }
  211. return 0
  212. }
  213. // int fstat(int fd, struct stat *statbuf);
  214. func Xfstat64(t *TLS, fd int32, statbuf uintptr) int32 {
  215. if err := unix.Fstat(int(fd), (*unix.Stat_t)(unsafe.Pointer(statbuf))); err != nil {
  216. if dmesgs {
  217. dmesg("%v: fd %d: %v FAIL", origin(1), fd, err)
  218. }
  219. t.setErrno(err)
  220. return -1
  221. }
  222. if dmesgs {
  223. dmesg("%v: fd %d: ok", origin(1), fd)
  224. }
  225. return 0
  226. }
  227. // off64_t lseek64(int fd, off64_t offset, int whence);
  228. func Xlseek64(t *TLS, fd int32, offset types.Off_t, whence int32) types.Off_t {
  229. n, err := unix.Seek(int(fd), int64(offset), int(whence))
  230. if err != nil {
  231. if dmesgs {
  232. dmesg("%v: %v FAIL", origin(1), err)
  233. }
  234. t.setErrno(err)
  235. return -1
  236. }
  237. if dmesgs {
  238. dmesg("%v: ok", origin(1))
  239. }
  240. return types.Off_t(n)
  241. }
  242. func Xfcntl64(t *TLS, fd, cmd int32, args uintptr) int32 {
  243. var arg uintptr
  244. if args != 0 {
  245. arg = *(*uintptr)(unsafe.Pointer(args))
  246. }
  247. n, _, err := unix.Syscall(unix.SYS_FCNTL, uintptr(fd), uintptr(cmd), arg)
  248. if err != 0 {
  249. if dmesgs {
  250. dmesg("%v: fd %v cmd %v", origin(1), fcntlCmdStr(fd), cmd)
  251. }
  252. t.setErrno(err)
  253. return -1
  254. }
  255. if dmesgs {
  256. dmesg("%v: %d %s %#x: %d", origin(1), fd, fcntlCmdStr(cmd), arg, n)
  257. }
  258. return int32(n)
  259. }
  260. // int rename(const char *oldpath, const char *newpath);
  261. func Xrename(t *TLS, oldpath, newpath uintptr) int32 {
  262. if err := unix.Rename(GoString(oldpath), GoString(newpath)); err != nil {
  263. if dmesgs {
  264. dmesg("%v: %v FAIL", origin(1), err)
  265. }
  266. t.setErrno(err)
  267. return -1
  268. }
  269. if dmesgs {
  270. dmesg("%v: ok", origin(1))
  271. }
  272. return 0
  273. }
  274. // int mknod(const char *pathname, mode_t mode, dev_t dev);
  275. func Xmknod(t *TLS, pathname uintptr, mode types.Mode_t, dev types.Dev_t) int32 {
  276. panic(todo(""))
  277. // if _, _, err := unix.Syscall(unix.SYS_MKNOD, pathname, uintptr(mode), uintptr(dev)); err != 0 {
  278. // t.setErrno(err)
  279. // return -1
  280. // }
  281. // return 0
  282. }
  283. // int utime(const char *filename, const struct utimbuf *times);
  284. func Xutime(t *TLS, filename, times uintptr) int32 {
  285. var a []unix.Timeval
  286. if times != 0 {
  287. a = make([]unix.Timeval, 2)
  288. a[0].Sec = (*utime.Utimbuf)(unsafe.Pointer(times)).Factime
  289. a[1].Sec = (*utime.Utimbuf)(unsafe.Pointer(times)).Fmodtime
  290. }
  291. if err := unix.Utimes(GoString(filename), a); err != nil {
  292. if dmesgs {
  293. dmesg("%v: %v FAIL", origin(1), err)
  294. }
  295. t.setErrno(err)
  296. return -1
  297. }
  298. if dmesgs {
  299. dmesg("%v: ok", origin(1))
  300. }
  301. return 0
  302. }
  303. // int chown(const char *pathname, uid_t owner, gid_t group);
  304. func Xchown(t *TLS, pathname uintptr, owner types.Uid_t, group types.Gid_t) int32 {
  305. if _, _, err := unix.Syscall(unix.SYS_CHOWN, pathname, uintptr(owner), uintptr(group)); err != 0 {
  306. t.setErrno(err)
  307. return -1
  308. }
  309. return 0
  310. }
  311. // int link(const char *oldpath, const char *newpath);
  312. func Xlink(t *TLS, oldpath, newpath uintptr) int32 {
  313. panic(todo(""))
  314. // if _, _, err := unix.Syscall(unix.SYS_LINK, oldpath, newpath, 0); err != 0 {
  315. // t.setErrno(err)
  316. // return -1
  317. // }
  318. // return 0
  319. }
  320. // int dup2(int oldfd, int newfd);
  321. func Xdup2(t *TLS, oldfd, newfd int32) int32 {
  322. panic(todo(""))
  323. // n, _, err := unix.Syscall(unix.SYS_DUP2, uintptr(oldfd), uintptr(newfd), 0)
  324. // if err != 0 {
  325. // t.setErrno(err)
  326. // return -1
  327. // }
  328. // return int32(n)
  329. }
  330. // unsigned int alarm(unsigned int seconds);
  331. func Xalarm(t *TLS, seconds uint32) uint32 {
  332. panic(todo(""))
  333. // n, _, err := unix.Syscall(unix.SYS_ALARM, uintptr(seconds), 0, 0)
  334. // if err != 0 {
  335. // panic(todo(""))
  336. // }
  337. // return uint32(n)
  338. }
  339. 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: */
  340. panic(todo(""))
  341. //TODO bp := tls.Alloc(347)
  342. //TODO defer tls.Free(347)
  343. //TODO // var ptr [78]int8 at bp, 78
  344. //TODO // var buf [256]int8 at bp+78, 256
  345. //TODO // var num [13]int8 at bp+334, 13
  346. //TODO var af int32 = int32((*sockaddr)(unsafe.Pointer(sa1)).sa_family)
  347. //TODO var a uintptr
  348. //TODO var scopeid uint32
  349. //TODO switch af {
  350. //TODO case 2:
  351. //TODO a = (sa1 + 4 /* &.sin_addr */)
  352. //TODO if (uint64(sl) < uint64(unsafe.Sizeof(sockaddr_in{}))) {
  353. //TODO return -6
  354. //TODO }
  355. //TODO mkptr4(tls, bp /* &ptr[0] */, a)
  356. //TODO scopeid = uint32(0)
  357. //TODO break
  358. //TODO case 10:
  359. //TODO a = (sa1 + 8 /* &.sin6_addr */)
  360. //TODO if (uint64(sl) < uint64(unsafe.Sizeof(sockaddr_in6{}))) {
  361. //TODO return -6
  362. //TODO }
  363. //TODO if Xmemcmp(tls, a, ts+88 /* "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xff\xff" */, uint64(12)) != 0 {
  364. //TODO mkptr6(tls, bp /* &ptr[0] */, a)
  365. //TODO } else {
  366. //TODO mkptr4(tls, bp /* &ptr[0] */, (a + uintptr(12)))
  367. //TODO }
  368. //TODO scopeid = (*sockaddr_in6)(unsafe.Pointer(sa1)).sin6_scope_id
  369. //TODO break
  370. //TODO default:
  371. //TODO return -6
  372. //TODO }
  373. //TODO if (node != 0) && (nodelen != 0) {
  374. //TODO *(*int8)(unsafe.Pointer(bp + 78 /* &buf[0] */)) = int8(0)
  375. //TODO if !((flags & 0x01) != 0) {
  376. //TODO reverse_hosts(tls, bp+78 /* &buf[0] */, a, scopeid, af)
  377. //TODO }
  378. //TODO if !(int32(*(*int8)(unsafe.Pointer(bp + 78 /* buf */))) != 0) && !((flags & 0x01) != 0) {
  379. //TODO Xabort(tls) //TODO-
  380. //TODO // unsigned char query[18+PTR_MAX], reply[512];
  381. //TODO // int qlen = __res_mkquery(0, ptr, 1, RR_PTR,
  382. //TODO // 0, 0, 0, query, sizeof query);
  383. //TODO // query[3] = 0; /* don't need AD flag */
  384. //TODO // int rlen = __res_send(query, qlen, reply, sizeof reply);
  385. //TODO // buf[0] = 0;
  386. //TODO // if (rlen > 0)
  387. //TODO // __dns_parse(reply, rlen, dns_parse_callback, buf);
  388. //TODO }
  389. //TODO if !(int32(*(*int8)(unsafe.Pointer(bp + 78 /* buf */))) != 0) {
  390. //TODO if (flags & 0x08) != 0 {
  391. //TODO return -2
  392. //TODO }
  393. //TODO Xinet_ntop(tls, af, a, bp+78 /* &buf[0] */, uint32(unsafe.Sizeof([256]int8{})))
  394. //TODO if scopeid != 0 {
  395. //TODO Xabort(tls) //TODO-
  396. //TODO // char *p = 0, tmp[IF_NAMESIZE+1];
  397. //TODO // if (!(flags & NI_NUMERICSCOPE) &&
  398. //TODO // (IN6_IS_ADDR_LINKLOCAL(a) ||
  399. //TODO // IN6_IS_ADDR_MC_LINKLOCAL(a)))
  400. //TODO // p = if_indextoname(scopeid, tmp+1);
  401. //TODO // if (!p)
  402. //TODO // p = itoa(num, scopeid);
  403. //TODO // *--p = '%';
  404. //TODO // strcat(buf, p);
  405. //TODO }
  406. //TODO }
  407. //TODO if Xstrlen(tls, bp+78 /* &buf[0] */) >= size_t(nodelen) {
  408. //TODO return -12
  409. //TODO }
  410. //TODO Xstrcpy(tls, node, bp+78 /* &buf[0] */)
  411. //TODO }
  412. //TODO if (serv != 0) && (servlen != 0) {
  413. //TODO var p uintptr = bp + 78 /* buf */
  414. //TODO var port int32 = int32(Xntohs(tls, (*sockaddr_in)(unsafe.Pointer(sa1)).sin_port))
  415. //TODO *(*int8)(unsafe.Pointer(bp + 78 /* &buf[0] */)) = int8(0)
  416. //TODO if !((flags & 0x02) != 0) {
  417. //TODO reverse_services(tls, bp+78 /* &buf[0] */, port, (flags & 0x10))
  418. //TODO }
  419. //TODO if !(int32(*(*int8)(unsafe.Pointer(p))) != 0) {
  420. //TODO p = itoa(tls, bp+334 /* &num[0] */, uint32(port))
  421. //TODO }
  422. //TODO if Xstrlen(tls, p) >= size_t(servlen) {
  423. //TODO return -12
  424. //TODO }
  425. //TODO Xstrcpy(tls, serv, p)
  426. //TODO }
  427. //TODO return 0
  428. }
  429. 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: */
  430. panic(todo(""))
  431. //TODO bp := tls.Alloc(28)
  432. //TODO defer tls.Free(28)
  433. //TODO //TODO union {
  434. //TODO //TODO struct sockaddr_in sin;
  435. //TODO //TODO struct sockaddr_in6 sin6;
  436. //TODO //TODO } sa = { .sin.sin_family = af };
  437. //TODO *(*struct {
  438. //TODO sin sockaddr_in
  439. //TODO _ [12]byte
  440. //TODO })(unsafe.Pointer(bp /* sa1 */)) = struct {
  441. //TODO sin sockaddr_in
  442. //TODO _ [12]byte
  443. //TODO }{} //TODO-
  444. //TODO (*sockaddr_in)(unsafe.Pointer(bp /* &sa1 */)).sin_family = sa_family_t(af) //TODO-
  445. //TODO var sl socklen_t
  446. //TODO if af == 10 {
  447. //TODO sl = uint32(unsafe.Sizeof(sockaddr_in6{}))
  448. //TODO } else {
  449. //TODO sl = uint32(unsafe.Sizeof(sockaddr_in{}))
  450. //TODO }
  451. //TODO var i int32
  452. //TODO *(*uintptr)(unsafe.Pointer(res)) = uintptr(0)
  453. //TODO // Load address argument into sockaddr structure
  454. //TODO if (af == 10) && (l == socklen_t(16)) {
  455. //TODO Xmemcpy(tls, (bp /* &sa1 */ /* &.sin6 */ + 8 /* &.sin6_addr */), a, uint64(16))
  456. //TODO } else if (af == 2) && (l == socklen_t(4)) {
  457. //TODO Xmemcpy(tls, (bp /* &sa1 */ /* &.sin */ + 4 /* &.sin_addr */), a, uint64(4))
  458. //TODO } else {
  459. //TODO *(*int32)(unsafe.Pointer(err)) = 3
  460. //TODO return 22
  461. //TODO }
  462. //TODO // Align buffer and check for space for pointers and ip address
  463. //TODO i = (int32(uintptr_t(buf) & (uint64(unsafe.Sizeof(uintptr(0))) - uint64(1))))
  464. //TODO if !(i != 0) {
  465. //TODO i = int32(unsafe.Sizeof(uintptr(0)))
  466. //TODO }
  467. //TODO if buflen <= (((uint64(5) * uint64(unsafe.Sizeof(uintptr(0)))) - uint64(i)) + uint64(l)) {
  468. //TODO return 34
  469. //TODO }
  470. //TODO buf += (uintptr(uint64(unsafe.Sizeof(uintptr(0))) - uint64(i)))
  471. //TODO buflen = buflen - (((uint64(5) * uint64(unsafe.Sizeof(uintptr(0)))) - uint64(i)) + uint64(l))
  472. //TODO (*hostent)(unsafe.Pointer(h)).h_addr_list = buf
  473. //TODO buf += (uintptr(uint64(2) * uint64(unsafe.Sizeof(uintptr(0)))))
  474. //TODO (*hostent)(unsafe.Pointer(h)).h_aliases = buf
  475. //TODO buf += (uintptr(uint64(2) * uint64(unsafe.Sizeof(uintptr(0)))))
  476. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list)) = buf
  477. //TODO Xmemcpy(tls, *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list)), a, uint64(l))
  478. //TODO buf += uintptr(l)
  479. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_addr_list + 1*8)) = uintptr(0)
  480. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases)) = buf
  481. //TODO *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases + 1*8)) = uintptr(0)
  482. //TODO switch Xgetnameinfo(tls, bp /* &sa1 */, sl, buf, uint32(buflen), uintptr(0), uint32(0), 0) {
  483. //TODO case -3:
  484. //TODO *(*int32)(unsafe.Pointer(err)) = 2
  485. //TODO return 11
  486. //TODO case -12:
  487. //TODO return 34
  488. //TODO default:
  489. //TODO fallthrough
  490. //TODO case -10:
  491. //TODO fallthrough
  492. //TODO case -11:
  493. //TODO fallthrough
  494. //TODO case -4:
  495. //TODO *(*int32)(unsafe.Pointer(err)) = 3
  496. //TODO return *(*int32)(unsafe.Pointer(X___errno_location(tls)))
  497. //TODO case 0:
  498. //TODO break
  499. //TODO }
  500. //TODO (*hostent)(unsafe.Pointer(h)).h_addrtype = af
  501. //TODO (*hostent)(unsafe.Pointer(h)).h_length = int32(l)
  502. //TODO (*hostent)(unsafe.Pointer(h)).h_name = *(*uintptr)(unsafe.Pointer((*hostent)(unsafe.Pointer(h)).h_aliases))
  503. //TODO *(*uintptr)(unsafe.Pointer(res)) = h
  504. //TODO return 0
  505. }
  506. // int getrlimit(int resource, struct rlimit *rlim);
  507. func Xgetrlimit64(t *TLS, resource int32, rlim uintptr) int32 {
  508. if _, _, err := unix.Syscall(unix.SYS_GETRLIMIT, uintptr(resource), uintptr(rlim), 0); err != 0 {
  509. t.setErrno(err)
  510. return -1
  511. }
  512. return 0
  513. }
  514. func newFtsent(t *TLS, info int, path string, stat *unix.Stat_t, err syscall.Errno) (r *fts.FTSENT) {
  515. var statp uintptr
  516. if stat != nil {
  517. statp = Xmalloc(t, types.Size_t(unsafe.Sizeof(unix.Stat_t{})))
  518. if statp == 0 {
  519. panic("OOM")
  520. }
  521. *(*unix.Stat_t)(unsafe.Pointer(statp)) = *stat
  522. }
  523. csp, errx := CString(path)
  524. if errx != nil {
  525. panic("OOM")
  526. }
  527. return &fts.FTSENT{
  528. Ffts_info: int32(info),
  529. Ffts_path: csp,
  530. Ffts_pathlen: uint32(len(path)),
  531. Ffts_statp: statp,
  532. Ffts_errno: int32(err),
  533. }
  534. }
  535. // DIR *opendir(const char *name);
  536. func Xopendir(t *TLS, name uintptr) uintptr {
  537. p := Xmalloc(t, uint32(unsafe.Sizeof(darwinDir{})))
  538. if p == 0 {
  539. panic("OOM")
  540. }
  541. fd := int(Xopen(t, name, fcntl.O_RDONLY|fcntl.O_DIRECTORY|fcntl.O_CLOEXEC, 0))
  542. if fd < 0 {
  543. if dmesgs {
  544. dmesg("%v: FAIL %v", origin(1), (*darwinDir)(unsafe.Pointer(p)).fd)
  545. }
  546. Xfree(t, p)
  547. return 0
  548. }
  549. if dmesgs {
  550. dmesg("%v: ok", origin(1))
  551. }
  552. (*darwinDir)(unsafe.Pointer(p)).fd = fd
  553. (*darwinDir)(unsafe.Pointer(p)).h = 0
  554. (*darwinDir)(unsafe.Pointer(p)).l = 0
  555. (*darwinDir)(unsafe.Pointer(p)).eof = false
  556. return p
  557. }
  558. // int chflags(const char *path, u_int flags);
  559. func Xchflags(t *TLS, path uintptr, flags uint32) int32 {
  560. if err := unix.Chflags(GoString(path), int(flags)); err != nil {
  561. if dmesgs {
  562. dmesg("%v: %v FAIL", origin(1), err)
  563. }
  564. t.setErrno(err)
  565. return -1
  566. }
  567. if dmesgs {
  568. dmesg("%v: ok", origin(1))
  569. }
  570. return 0
  571. }