about summary refs log tree commit diff stats
path: root/subx/examples/ex1.subx
diff options
context:
space:
mode:
authorKartik Agaram <vc@akkartik.com>2018-11-23 00:28:16 -0800
committerKartik Agaram <vc@akkartik.com>2018-11-23 00:42:30 -0800
commitd373c008b3ef54845175db7b8e8319d750a5b7bf (patch)
tree08daa8370d16d82770f3b72580c8e8a254cafde5 /subx/examples/ex1.subx
parent886630e9376d0f8198117aac3c0d83938bb2c1c6 (diff)
downloadmu-d373c008b3ef54845175db7b8e8319d750a5b7bf.tar.gz
4763 - back to the 'trivial' crenshaw2-1 compiler
This time I've ported (and test-driven) 'GetChar' and 'GetNum'. The new
tests bring together our new testable interfaces for read() and exit().
Diffstat (limited to 'subx/examples/ex1.subx')
0 files changed, 0 insertions, 0 deletions
href='/akkartik/mu/commit/translate_subx?h=hlt&id=ff8ec9bcff7577ba923fe7868ea62ecceed55ee7'>ff8ec9bc ^
099f0d5d ^
ff8ec9bc ^
418ea7d3 ^
ff8ec9bc ^
90538f23 ^
71e4f381 ^
90538f23 ^
ff8ec9bc ^
90538f23 ^
ff8ec9bc ^
6488bfcf ^
ff8ec9bc ^

90538f23 ^
ff8ec9bc ^
90538f23 ^
f7746778 ^
69e477b1 ^
f7746778 ^
531f14c9 ^
9516dfa0 ^
71e4f381 ^
da438fa9 ^
71e4f381 ^

69e477b1 ^

56c92481 ^
c26aef11 ^
69e477b1 ^
7205c246 ^
69e477b1 ^

56c92481 ^
c26aef11 ^
56c92481 ^



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
         









                                                                              
 
      
 
                                                                          
 
                                                                         
 
                                                                          
 
                                                                         
 
                                                          
 
                                                                           
 
                                                                        
 

                                                                          
 
                                                                       
 
                                  
                                                                                  
                                    
 
                                                                                                                                         
    
                                          

        

                                        
                                                                                    
                                                                                             
    
                                            

        
 
                                                                         



                                            
#!/bin/sh
# Translate SubX files to a bootable disk image.
#
# A couple of gotchas:
# * Many phases here have no error-checking. Perhaps I should use a
#   version of translate_subx_debug for baremetal.
# * Don't pass in numbered .subx files without translated .mu files. Our test
#   harness is in test.mu, and only Mu programs can run tests in baremetal.
#
# The top level is in general not as rigorous about avoiding dependency cycles
# as the lower-level tools in linux/

set -e

cat $*          |linux/braces                                   > a.braces

cat a.braces    |linux/calls                                    > a.calls

cat a.calls     |linux/sigils                                   > a.sigils

cat a.sigils    |linux/tests                                    > a.tests

# no assort since baremetal SubX doesn't have segments yet

cat a.tests     |linux/dquotes                                  > a.dquotes

cat a.dquotes   |linux/pack                                     > a.pack

cat a.pack      |linux/survey_baremetal   > labels
cat a.pack      |linux/labels_baremetal     labels              > a.survey

cat a.survey    |linux/hex                                      > a.bin

# Create code.img containing a.bin
dd if=/dev/zero of=code.img count=20160  # 20*16*63 512-byte sectors = almost 10MB
dd if=a.bin of=code.img conv=notrunc

if [ `stat --printf="%s" a.bin` -ge 322560 ]  # 10 tracks * 63 sectors per track * 512 bytes per sector (keep this sync'd with boot.subx)
then
  echo "a.bin won't all be loaded on boot"
  exit 1
fi

# Latter half of disk is for debug info.
dd if=labels of=code.img seek=10080 conv=notrunc  # keep this sync'd with abort.subx
if [ `stat --printf="%s" labels` -ge 524288 ]  # 4 reads * 256 sectors * 512 bytes per sector
then
  echo "labels won't all be loaded on abort"
  exit 1
fi

if [ `wc -l < labels` -gt 16384 ]  # 0x4000 stream capacity in abort.subx
then
  echo "abort will go into infinite regress"
  exit 1
fi