pc.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. #include "all.h"
  2. #include "io.h"
  3. Mconf mconf;
  4. static void
  5. mconfinit(void)
  6. {
  7. int nf, pgsize = 0;
  8. ulong size, userpgs = 0, userused = 0;
  9. char *ln, *sl;
  10. char *fields[2];
  11. Biobuf *bp;
  12. Mbank *mbp;
  13. size = 64*MB;
  14. bp = Bopen("#c/swap", OREAD);
  15. if (bp != nil) {
  16. while ((ln = Brdline(bp, '\n')) != nil) {
  17. ln[Blinelen(bp)-1] = '\0';
  18. nf = tokenize(ln, fields, nelem(fields));
  19. if (nf != 2)
  20. continue;
  21. if (strcmp(fields[1], "pagesize") == 0)
  22. pgsize = atoi(fields[0]);
  23. else if (strcmp(fields[1], "user") == 0) {
  24. sl = strchr(fields[0], '/');
  25. if (sl == nil)
  26. continue;
  27. userpgs = atol(sl+1);
  28. userused = atol(fields[0]);
  29. }
  30. }
  31. Bterm(bp);
  32. if (pgsize > 0 && userpgs > 0)
  33. size = (((userpgs - userused)*3LL)/4)*pgsize;
  34. }
  35. mconf.memsize = size;
  36. mbp = mconf.bank;
  37. mbp->base = 0x10000000; /* fake addresses */
  38. mbp->limit = mbp->base + size;
  39. mbp++;
  40. mconf.nbank = mbp - mconf.bank;
  41. }
  42. ulong
  43. meminit(void)
  44. {
  45. conf.nmach = 1;
  46. mconfinit();
  47. return mconf.memsize;
  48. }
  49. /*
  50. * based on libthread's threadsetname, but drags in less library code.
  51. * actually just sets the arguments displayed.
  52. */
  53. void
  54. procsetname(char *fmt, ...)
  55. {
  56. int fd;
  57. char *cmdname;
  58. char buf[128];
  59. va_list arg;
  60. va_start(arg, fmt);
  61. cmdname = vsmprint(fmt, arg);
  62. va_end(arg);
  63. if (cmdname == nil)
  64. return;
  65. snprint(buf, sizeof buf, "#p/%d/args", getpid());
  66. if((fd = open(buf, OWRITE)) >= 0){
  67. write(fd, cmdname, strlen(cmdname)+1);
  68. close(fd);
  69. }
  70. free(cmdname);
  71. }
  72. void
  73. newproc(void (*f)(void *), void *arg, char *text)
  74. {
  75. int kid = rfork(RFPROC|RFMEM|RFNOWAIT);
  76. if (kid < 0)
  77. sysfatal("can't fork: %r");
  78. if (kid == 0) {
  79. procsetname("%s", text);
  80. (*f)(arg);
  81. exits("child returned");
  82. }
  83. }