data2s.c 796 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #include <u.h>
  2. #include <libc.h>
  3. #include <bio.h>
  4. void
  5. main(int argc, char *argv[])
  6. {
  7. Biobuf bin, bout;
  8. long len, slen;
  9. int c;
  10. if(argc != 2){
  11. fprint(2, "usage: data2s name\n");
  12. exits("usage");
  13. }
  14. Binit(&bin, 0, OREAD);
  15. Binit(&bout, 1, OWRITE);
  16. for(len=0; (c=Bgetc(&bin))!=Beof; len++){
  17. if((len&7) == 0)
  18. Bprint(&bout, "DATA %scode+%ld(SB)/8, $\"", argv[1], len);
  19. if(c)
  20. Bprint(&bout, "\\%uo", c);
  21. else
  22. Bprint(&bout, "\\z");
  23. if((len&7) == 7)
  24. Bprint(&bout, "\"\n");
  25. }
  26. slen = len;
  27. if(len & 7){
  28. while(len & 7){
  29. Bprint(&bout, "\\z");
  30. len++;
  31. }
  32. Bprint(&bout, "\"\n");
  33. }
  34. Bprint(&bout, "GLOBL %scode+0(SB), $%ld\n", argv[1], len);
  35. Bprint(&bout, "GLOBL %slen+0(SB), $4\n", argv[1]);
  36. Bprint(&bout, "DATA %slen+0(SB)/4, $%ld\n", argv[1], slen);
  37. exits(0);
  38. }