9 Okay, so I keep getting stuck with the class initialization. It is very
10 complex and the initialization work is just going to be duplicated twice
11 in the kernel itself. I think what I need is a generic `ClassLoader` which
12 can use any kind of interface to access stored JAR data or something in
13 memory. I think this would be the best solution... have an interface for
14 the `ClassLoader` which can read raw memory. Then it could be shared within
15 the kernel itself for loading and a bootstrap.
19 I think what I need to do is actually take advantage of the Java compiler
20 and such. I need to have annotations on code instructions.
24 Java 7 lacks annotations on type parameters though and it would violate the
25 specification to have them, but there are other ways to do it.
29 I was walking and I was thinking. The main question I asked was:
30 "How do you dynamically initialize the kernel and the run-time to be as
31 simple as possible and not require heavy VM lifting on it?". So I just had
32 this idea, I know my current work is trying to initialize a ROM that is
33 built from single parts. It is looking rather complicated to initialize the
34 class data, to initialize any strings, and to initialize the constant pools
35 recursively for every possible class that might be used by the kernel's
36 execution path. I do know that going through the constant pool and doing
37 lookups is quite complicated. I need to initialize the VTables, the pools,
38 and everything else about the class. I think it would be easiest to
39 pre-initialize everything I absolutely know about a class within the JAR at
40 its combination time. Due to how libraries and such work, this information
41 cannot be included in every JAR. So this begs the question, how do I reduce
42 the very big and complex potential duplication of everything. I got past the
43 compiler and it works, but I am rather stuck with it and how it works. I would
44 very very likely end up exactly where I am now with the same result. So how
45 do I solve this problem? How do I get through this?
49 Okay I had an idea. What if I did staged dynamic linking. Basically like a
50 rocket going off... The rocket cannot reach space on a single stage so it
51 needs multiple stages in order to work. What if just in the boot ROM the only
52 thing that was initialized was the constant pool of every class. If I know
53 where something is statically method wise, like I know its position within
54 the JAR file. But when it comes to fields and such, I do not exactly know
55 where the offsets are. The main important thing that I know that must exist
56 are the static methods. I think I might be able to get away with a sweeping
57 initialization of sorts for the constant pool. So this means that there must
58 always be at the start of the constant pool, a reference to the pool pointer
59 for the current class. Not sure how to integrate it since it is kind of an
60 egde though but it is something popping into my head. But effectively once I
61 know the positions of all the static methods. I can perform more
62 initialization routines as needed.
66 So in the boot class, there must be initialized constant pools with all the
67 various values and such. However instead of going crazy and initializing
68 every possible thing about the constant pool at JAR link time, instead it will
69 only handle `STRING` which will just be pointers in the ROM to the string data
70 and not used strings (too complicated), then the other initialized thing will
71 be class indexes, or like {@code -1} if they are not defined yet, and then
72 finally any `InvokedMethod` will have a pointer to it as well. Of course all
73 the pool entries need to be recursively initialized but I can use the same
74 strategy I was thinking of for the super complex initialization with the
75 memory values and what is written where. Of course, field accesses for statics
76 is going to be very important because I will want to store variables somewhere
77 and I do want that to exist for the bootstrap process. So this just makes these
80 * CLASS_NAME, the index of the class will be kept as -1 if unknown.
81 * CLASS_POOL, a pointer to the constant pool of whatever class (in bootRAM).
82 * STRING, just a raw pointer to the UTF string contents in memory somewhere.
83 * FIELD_OFFSET, static only, instances will be set to -1.
84 * INVOKED_METHOD, direct pointer reference to the code area.
85 * WHERE_IS_THIS, the where information will be pre-included to help debug the
86 sweeping linker initializer.
88 Not going to initialize `INDEXED_METHOD` because I do not exactly know where
89 it could end up even though it would be known statically. So this will keep
90 everything at the limitation of statics only.
94 The fonts are complete after two years!