<div dir="ltr">But Wojtek also wants to have control as to where the code is loaded.<div><br></div><div>So this morning I had a quick look in chapter 14 of the new 'Project Oberon' and in the source files that control the boot process. At the moment most addresses are hard wired and difficult to decipher for a novice.</div><div><br></div><div>so I think what might be done is: make a 'boot parameter' module, that exports just the required variables -- with copious explanation --, that is imported into the regular bootloader, Kernel etc.</div><div><br></div><div>I think it will have 2 advantages: people with special requirements have some insight into what is possible and what not, and will be easily helped. And the discussions will be more to the point, and not "Oberon is this and that, and needs to be .. and have .."</div><div>That is rather fruitless imho. You need to have a solid computer science background and be deep into the Dijkstra / Wirth way of thinking to hack Oberon successfully. It is a real singular beast in that respect.</div><div><br></div><div>At the same time of course, as it stands it works beautifully in an embedded context, provided the bootloading process is easily accessible.</div><div><br></div><div>I would love to do it, but unfortunately I dont have access to an fpga board and an fpga programming setup.</div><div><br></div><div>cheers,</div><div><br></div><div>j.</div><div><br></div><div><br></div><div><br></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Aug 27, 2015 at 11:26 AM, Jörg Straube <span dir="ltr"><<a href="mailto:joerg.straube@iaeth.ch" target="_blank">joerg.straube@iaeth.ch</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="auto"><div><span></span></div><div><div>Wojtek</div><div><br></div><div>You said</div><div>1) sometimes it is necessary to put data in fast memory (I think you mean BRAM)</div><div>2) you would like to process your ADC dara (stored in BRAM) in Oberon.</div><div><br></div><div>Oberon works with what you call slow memory. So if you want to process your fast data with the slow Oberon, why not put the data in the slow memory in the first place?</div><div>- Jan proposes a copy approach BRAM to SRAM and then process by Oberon</div><div>- Chris proposes a mapped memory aaproach.</div><div><br></div><div>To understand the Oberon memory layout have a look at figure 8.1 in chapter 8 of project oberon.</div><div>You see basically that the Oberon system splits memory in four blocks</div><div>A memory for module code</div><div>B memory for procedure variables (called stack)</div><div>C memory for dynamic variables allocated with NEW (called heap)</div><div>D memory for IO (display frame buffer and IO registers)</div><div><br></div><div>This layout is flexibly established during booting by two constants in the boot record, called "heapOrg" and "heapLimit".</div><div>A starts at 0 and grows upwards</div><div>B starts at heapOrg and grows downwards</div><div>C starts at heapOrg and grows upward til heapLimit</div><div>D starts at heapOrg+heapLimit</div><div><br></div><div>Now, I think you don't like Jan's copy approach. So you could do the following memory map approach: Reduce "heapLimit" and map the memory range just below the VGA framebuffer to your BRAM (this mapping has to be done in Verilog)</div><div>You can declare in Oberon a safe TYPE to your ADC data (e.g. POINTER TO ARRAY 256 OF BYTE) and allocate the start address of your mapped BRAM memory to a pointer variable.</div><div><br>br, Jörg<div><div class="h5"><div><br>Am 26.08.2015 um 20:15 schrieb Jan de Kruyf <<a href="mailto:jan.de.kruyf@gmail.com" target="_blank">jan.de.kruyf@gmail.com</a>>:<br><br></div><blockquote type="cite"><div><div dir="ltr">skulski,<br><div>we dont 'object'.</div><div>But we can do without a version for every toy about town, on good scientific grounds. Oberon tries to be a safe language. meaning that any person can use it, without having to be afraid to fall into some silly trap. And it tries to be a minimalistic language that is very easy to learn for a novice.</div><div><br></div><div>Further I am sure that by using ADR(v) and MOVE(s, d, n) and or PUT(a, x) you can set up an array of variables, obtain the address and dump your data into it.</div><div>That is the way it has been done from day one in most languages. In fact if you would bother to study a few low level file systems in a few languages you will find out that the Oberon way of doing things is by far the easiest to understand for a novice.</div><div>And you are free to set up a higher level facility for your needs, in a module that you call as you need it. I am sure the execution time will be equal to any higher level construct in the language. </div><div>This is the Oberon way of doing things. It works and it is fully transparent. You can know what your code is doing at a hardware level. There are no hidden layers build in by the compiler to obfuscate your understanding of the process.</div><div><br></div><div>To do it any other way would mean that we have to revise the language just about every 6 months as and when new hardware gadgets are incorporated in micro-controllers / fpga's. And the book would not be 17 pages but 1700 pages long. </div><div>This is the trade off the designer consciously chose. Also in the 80's many keywords could have been added to the language ( I know, I was around then) to make it "easier" and more "modern". </div><div><br></div><div>What you want is something like python (but you would not like the execution speed) where anybody can add features to the runtime.</div><div>Perhaps, since Oberon does not guarantee a real time response, you might also like to look at a few other languages with a different ideology. </div><div>C or if you are brave you might try Ada, there you can do an address overlay or assign a variable to an address. But in order to support things like that in a safe way, the language has grown horribly complex. </div><div>So personally I rather like the Oberon minimalistic way. It has nothing to do with "old-fashioned", but everything with "elegant". </div><div><br></div><div>j.</div><div><br></div><div>. . . . . . </div><div>Since the Romans have taught us "Simplex Veri Sigillum" —that is: simplicity is the hallmark of truth— we should know better, but complexity continues to have a morbid attraction. When you give for an academic audience a lecture that is crystal clear from alpha to omega, your audience feels cheated and leaves the lecture hall commenting to each other: "That was rather trivial, wasn't it?" The sore truth is that complexity sells better. (It is not only the computer industry that has discovered that.) And it is even more diabolical in that we even use the complexity of our own constructs to impress ourselves. I have often been impressed by the cleverness of my own first solutions; invariably the joy of the subsequent discovery how to streamline the argument was tempered by a feeling of regret that my cleverness was unnecessary after all. It is a genuine sacrifice to part from one's ingenuities, no matter how contorted, Also, many a programmer derives a major part of his professional excitement from not quite understanding what he is doing, from the daring risks he takes and from the struggle to find the bugs he should not have introduced in the first place.<br></div><div><a href="https://www.cs.utexas.edu/~EWD/transcriptions/EWD08xx/EWD898.html" target="_blank">https://www.cs.utexas.edu/~EWD/transcriptions/EWD08xx/EWD898.html</a><br></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Aug 26, 2015 at 5:28 PM, <span dir="ltr"><<a href="mailto:skulski@pas.rochester.edu" target="_blank">skulski@pas.rochester.edu</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>> Hi Markus,<br>
><br>
>> So Project Oberon _is_ and should be:<br>
> ...<br>
><br>
> Just to be clear, Project Oberon is the design of an operating system, a<br>
> compiler, and a computer, by Niklaus Wirth and Juerg Gutknecht.<br>
><br>
> Cheers,<br>
> Paul<br>
<br>
</span>Paul:<br>
<br>
I would rephrase your statement:<br>
<br>
"Project Oberon WAS the design of an operating system, a compiler, and a<br>
<span>computer, by Niklaus Wirth and Juerg Gutknecht."<br>
<br>
</span>That was in 1985. Now it is 2015. How is this system useful today? We can<br>
say "it is a museum piece of historical interest". Fine. Is this what you<br>
and NW want? (JG seems out of the loop.)<br>
<br>
My point is this: if the FPGA Oberon System is running in the FPGA, then<br>
stop pretending it is running on Ceres. These days are long gone. The FPGA<br>
is an entirely different world from the personal workstation. The first<br>
step should be "acknowledge that FPGA is all about custom designed HW".<br>
FPGA is not static. FPGA is constantly changing, even five times a day.<br>
The software layer should provide convenient means of accomodating to such<br>
changes.<br>
<br>
I liked Chris post about SYSTEM.Get and System.Put. His solution is great.<br>
However, it is low-level. It is similar to #define in C. We use #define a<br>
lot in our C programs in exactly the way Chris pointed out. Is this all<br>
that Oberon language has to offer for HW interfacing? If so then let be<br>
it. I think that the language can do better, but if you guys object, then<br>
what can we do?<br>
<br>
How can the language do better? Imagine a BRAM into which we are<br>
collecting the waveform from the ADC. (We are doing just that.) I would<br>
like to see a high level declaration:<br>
<br>
VAR my_samples: ARRAY 8191 OF SHORT AT ADDRESS <address>;<br>
<br>
Then I can use this array in the code in a type-safe way. As of today I<br>
must use Chris' SYSTEM.Get, which is low-level, error prone, and more<br>
difficult to maintain. So we keep claiming that Oberon is a "high level<br>
language" despite the #define mindset which we have to use to solve an<br>
everyday problem which is critical for the FPGA interfacing.<br>
<br>
How about different memories, the BRAM, SRAM, SDRAM? I insist that we need<br>
a mechanism to run critical pieces from BRAM, and less critical pieces<br>
from slower memory. Is it going to be addressed or ignored by the Oberon<br>
System gurus?<br>
<br>
Another matter are those 16 registers and a single GPIO port. This was<br>
tailored towards a particular project. Completely insufficient for any<br>
other project.<br>
<br>
Wojtek<br>
<div><div><br>
<br>
--<br>
<a href="mailto:Oberon@lists.inf.ethz.ch" target="_blank">Oberon@lists.inf.ethz.ch</a> mailing list for ETH Oberon and related systems<br>
<a href="https://lists.inf.ethz.ch/mailman/listinfo/oberon" rel="noreferrer" target="_blank">https://lists.inf.ethz.ch/mailman/listinfo/oberon</a><br>
</div></div></blockquote></div><br></div>
</div></blockquote><blockquote type="cite"><div><span>--</span><br><span><a href="mailto:Oberon@lists.inf.ethz.ch" target="_blank">Oberon@lists.inf.ethz.ch</a> mailing list for ETH Oberon and related systems</span><br><span><a href="https://lists.inf.ethz.ch/mailman/listinfo/oberon" target="_blank">https://lists.inf.ethz.ch/mailman/listinfo/oberon</a></span><br></div></blockquote></div></div></div></div></div><br>--<br>
<a href="mailto:Oberon@lists.inf.ethz.ch">Oberon@lists.inf.ethz.ch</a> mailing list for ETH Oberon and related systems<br>
<a href="https://lists.inf.ethz.ch/mailman/listinfo/oberon" rel="noreferrer" target="_blank">https://lists.inf.ethz.ch/mailman/listinfo/oberon</a><br>
<br></blockquote></div><br></div>