mirror of
https://github.com/italicsjenga/gba.git
synced 2025-01-22 23:56:32 +11:00
explained #[start] better
This commit is contained in:
parent
f0121f683a
commit
2b69433807
6 changed files with 44 additions and 20 deletions
|
@ -83,12 +83,18 @@ much as possible.
|
|||
fn main(_argc: isize, _argv: *const *const u8) -> isize {
|
||||
```
|
||||
|
||||
This is our `#[start]`. We call it `main`, but the signature looks a lot more
|
||||
like the main from C than it does the main from Rust. Actually, those inputs are
|
||||
useless, because nothing will be calling our code from the outside. Similarly,
|
||||
it's totally undefined to return anything, so the fact that we output an `isize`
|
||||
is vacuously true at best. We just have to use this function signature because
|
||||
that's how `#[start]` works, not because the inputs and outputs are meaningful.
|
||||
This is our `#[start]`. We call it `main`, but it's not like a `main` that you'd
|
||||
see in a Rust program. It's _more like_ the sort of `main` that you'd see in a C
|
||||
program, but it's still **not** that either. If you compile a `#[start]` program
|
||||
for a target with an OS such as `arm-none-eabi-nm` you can open up the debug
|
||||
info and see that your result will have the symbol for the C `main` along side
|
||||
the symbol for the start `main` that we write here. Our start `main` is just its
|
||||
own unique thing, and the inputs and outputs have to be like that because that's
|
||||
how `#[start]` is specified to work in Rust.
|
||||
|
||||
If you think about it for a moment you'll probably realize that, those inputs
|
||||
and outputs are totally useless to us on a GBA. There's no OS on the GBA to call
|
||||
our program, and there's no place for our program to "return to" when it's done.
|
||||
|
||||
```rust
|
||||
unsafe {
|
||||
|
|
|
@ -209,12 +209,17 @@ much as possible.</p>
|
|||
<pre><pre class="playpen"><code class="language-rust">#[start]
|
||||
fn main(_argc: isize, _argv: *const *const u8) -> isize {
|
||||
</code></pre></pre>
|
||||
<p>This is our <code>#[start]</code>. We call it <code>main</code>, but the signature looks a lot more
|
||||
like the main from C than it does the main from Rust. Actually, those inputs are
|
||||
useless, because nothing will be calling our code from the outside. Similarly,
|
||||
it's totally undefined to return anything, so the fact that we output an <code>isize</code>
|
||||
is vacuously true at best. We just have to use this function signature because
|
||||
that's how <code>#[start]</code> works, not because the inputs and outputs are meaningful.</p>
|
||||
<p>This is our <code>#[start]</code>. We call it <code>main</code>, but it's not like a <code>main</code> that you'd
|
||||
see in a Rust program. It's <em>more like</em> the sort of <code>main</code> that you'd see in a C
|
||||
program, but it's still <strong>not</strong> that either. If you compile a <code>#[start]</code> program
|
||||
for a target with an OS such as <code>arm-none-eabi-nm</code> you can open up the debug
|
||||
info and see that your result will have the symbol for the C <code>main</code> along side
|
||||
the symbol for the start <code>main</code> that we write here. Our start <code>main</code> is just its
|
||||
own unique thing, and the inputs and outputs have to be like that because that's
|
||||
how <code>#[start]</code> is specified to work in Rust.</p>
|
||||
<p>If you think about it for a moment you'll probably realize that, those inputs
|
||||
and outputs are totally useless to us on a GBA. There's no OS on the GBA to call
|
||||
our program, and there's no place for our program to "return to" when it's done.</p>
|
||||
<pre><pre class="playpen"><code class="language-rust">
|
||||
# #![allow(unused_variables)]
|
||||
#fn main() {
|
||||
|
|
|
@ -234,6 +234,10 @@ pub unsafe fn mode3_pixel(col: isize, row: isize, color: u16) {
|
|||
(VRAM as *mut u16).offset(col + row * SCREEN_WIDTH).write_volatile(color);
|
||||
}
|
||||
</code></pre></pre>
|
||||
<p>Exact same program that we started with, but much easier to read.</p>
|
||||
<p>Of course, in the full <code>gba</code> crate that this book is a part of we have these and
|
||||
other elements all labeled and sorted out for you. Still, for educational
|
||||
purposes it's often best to do it yourself at least once.</p>
|
||||
|
||||
</main>
|
||||
|
||||
|
|
|
@ -363,12 +363,17 @@ much as possible.</p>
|
|||
<pre><pre class="playpen"><code class="language-rust">#[start]
|
||||
fn main(_argc: isize, _argv: *const *const u8) -> isize {
|
||||
</code></pre></pre>
|
||||
<p>This is our <code>#[start]</code>. We call it <code>main</code>, but the signature looks a lot more
|
||||
like the main from C than it does the main from Rust. Actually, those inputs are
|
||||
useless, because nothing will be calling our code from the outside. Similarly,
|
||||
it's totally undefined to return anything, so the fact that we output an <code>isize</code>
|
||||
is vacuously true at best. We just have to use this function signature because
|
||||
that's how <code>#[start]</code> works, not because the inputs and outputs are meaningful.</p>
|
||||
<p>This is our <code>#[start]</code>. We call it <code>main</code>, but it's not like a <code>main</code> that you'd
|
||||
see in a Rust program. It's <em>more like</em> the sort of <code>main</code> that you'd see in a C
|
||||
program, but it's still <strong>not</strong> that either. If you compile a <code>#[start]</code> program
|
||||
for a target with an OS such as <code>arm-none-eabi-nm</code> you can open up the debug
|
||||
info and see that your result will have the symbol for the C <code>main</code> along side
|
||||
the symbol for the start <code>main</code> that we write here. Our start <code>main</code> is just its
|
||||
own unique thing, and the inputs and outputs have to be like that because that's
|
||||
how <code>#[start]</code> is specified to work in Rust.</p>
|
||||
<p>If you think about it for a moment you'll probably realize that, those inputs
|
||||
and outputs are totally useless to us on a GBA. There's no OS on the GBA to call
|
||||
our program, and there's no place for our program to "return to" when it's done.</p>
|
||||
<pre><pre class="playpen"><code class="language-rust">
|
||||
# #![allow(unused_variables)]
|
||||
#fn main() {
|
||||
|
@ -761,6 +766,10 @@ pub unsafe fn mode3_pixel(col: isize, row: isize, color: u16) {
|
|||
(VRAM as *mut u16).offset(col + row * SCREEN_WIDTH).write_volatile(color);
|
||||
}
|
||||
</code></pre></pre>
|
||||
<p>Exact same program that we started with, but much easier to read.</p>
|
||||
<p>Of course, in the full <code>gba</code> crate that this book is a part of we have these and
|
||||
other elements all labeled and sorted out for you. Still, for educational
|
||||
purposes it's often best to do it yourself at least once.</p>
|
||||
|
||||
</main>
|
||||
|
||||
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
Loading…
Add table
Reference in a new issue