23 Commits

Author SHA1 Message Date
Michael Droogleever Fortuyn
7ba80d5e0b Stable nb block and editions 2019-11-30 21:46:06 +01:00
Michael Droogleever Fortuyn
d6b866a4dd More stable fixes 2019-11-30 21:24:05 +01:00
Michael Droogleever Fortuyn
e957a7ccc1 finish 2019-11-30 20:47:27 +01:00
Michael Droogleever Fortuyn
c7c004bc20 bump 2019-11-30 20:39:29 +01:00
Michael Droogleever Fortuyn
ea52aa2ea6 autofix 2019-11-30 20:38:09 +01:00
Michael Droogleever Fortuyn
ded6d7f3d8 manual fixes 2019-11-30 20:37:55 +01:00
Michael Droogleever Fortuyn
037bcc3c64 fix1 2019-11-30 20:29:44 +01:00
Michael Droogleever Fortuyn
707ad39a62 Update panics 2019-11-23 15:51:34 +01:00
Michael Droogleever Fortuyn
ec972af59a Version WIP 2019-11-23 15:36:44 +01:00
Michael Droogleever Fortuyn
389e30a0cd Stable rust in setup 2019-11-23 12:07:31 +01:00
droogmic
d16c5af8f7 Merge pull request #14 from beagleknight/fix/microbit-display-example
fix: microbit display example
2019-11-22 08:16:44 +01:00
droogmic
d2351e6049 Merge pull request #8 from rossjones/patch-1
Update macOS setup text
2019-11-22 08:16:27 +01:00
David Morcillo
d6e4a70e25 fix: microbit display example 2019-11-05 16:40:48 +01:00
Ross Jones
eeabf6b056 Update macOS setup text
The gcc-arm-embedded cask has been removed in favour of a not-yet-implemented normal homebrew formula.
I've tried the above however (as documented in the linked casks PR) and it works as advertised for now.
2019-10-26 14:57:02 +01:00
droogmic
0fdc235a3c Merge pull request #6 from mogenson/master
fixup serial output example so that it builds correctly
2019-10-16 21:08:14 +02:00
droogmic
aa3cc8bcb3 Merge pull request #7 from dstutman/patch-1
Fixes rust-lld errors when building example
2019-10-16 21:07:47 +02:00
Daniel Stutman
8545dda435 Fixes rust-lld errors when building example
Building the previous main.rs failed with: ERROR(cortex-m-rt): The interrupt vectors are missing.
Including the microbit crate in the example fixes this.
2019-04-20 22:16:56 +02:00
Michael Mogenson
7641877efe Remove unused mut
`gpio` does not need to be mutable. Remove `mut` to silence build
warning.
2019-03-27 11:39:35 -04:00
Michael Mogenson
d37d5726ce write_fmt() method needed for write!() macro
Include `use core::fmt::Write;` in serial example.
2019-03-27 11:37:44 -04:00
droogmic
2e48356a55 Merge pull request #4 from mogenson/master
Fixup Getting Started -> Building page
2019-03-17 10:28:26 +01:00
Michael Mogenson
feec6bfb2a Bump microbit crate version to the latest: ~0.7 2019-03-14 10:49:41 -04:00
Michael Mogenson
78bf6ff538 Remove semicolon after #[entry]
Otherwise you get the following build error:

```
error: expected item after attributes
 --> src/main.rs:8:8
  |
8 | #[entry];
  |        ^
```

This one confused me for awhile.
2019-03-14 10:47:26 -04:00
Michael Mogenson
9c6bcd2ee8 Use panic-halt crate, panic-abort requires nightly toolchain features
When trying to follow the Getting Started->Building instructions, the
`panic-abort` crate throws the following build error on rust stable
version 1.33:

```
   Compiling panic-abort v0.3.1
error[E0554]: #![feature] may not be used on the stable release channel
  --> /home/mike/.cargo/registry/src/github.com-1ecc6299db9ec823/panic-abort-0.3.1/src/lib.rs:22:1
   |
22 | #![feature(core_intrinsics)]
   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^

error[E0554]: #![feature] may not be used on the stable release channel
  --> /home/mike/.cargo/registry/src/github.com-1ecc6299db9ec823/panic-abort-0.3.1/src/lib.rs:23:1
   |
23 | #![feature(panic_handler)]
   | ^^^^^^^^^^^^^^^^^^^^^^^^^^

error: aborting due to 2 previous errors

For more information about this error, try `rustc --explain E0554`.
error: Could not compile `panic-abort`.

To learn more, run the command again with --verbose.
```

Switch to the `panic-halt` crate that builds on stable and provides the
`#[panic_handler]` function necesary to get a minimal successful build.
2019-03-14 10:37:41 -04:00
17 changed files with 75 additions and 74 deletions

View File

@@ -2,5 +2,5 @@ target remote :3333
monitor arm semihosting enable
set print asm-demangle on
load
#break main
break main
continue

View File

@@ -1,9 +1,10 @@
[package]
name = "display"
version = "0.1.0"
version = "0.2.0"
edition = "2018"
[dependencies]
cortex-m-rt="~0.6"
cortex-m-semihosting="~0.3"
panic-semihosting = "~0.5"
microbit="~0.6"
microbit="~0.8"

View File

@@ -69,10 +69,10 @@ impl Display {
/// Clear display
pub fn clear(&mut self) {
for row in &mut self.rows {
row.set_low();
row.set_low().unwrap();
}
for col in &mut self.cols {
col.set_high();
col.set_high().unwrap();
}
}
@@ -97,18 +97,18 @@ impl Display {
let loops = duration_ms / (self.rows.len() as u32 * self.delay_ms);
for _ in 0..loops {
for (row_line, led_matrix_row) in self.rows.iter_mut().zip(led_matrix.iter()) {
row_line.set_high();
row_line.set_high().unwrap();
for (col_line, led_matrix_val) in self.cols.iter_mut().zip(led_matrix_row.iter()) {
// We are keeping it simple, and not adding brightness
if *led_matrix_val > 0 {
col_line.set_low();
col_line.set_low().unwrap();
}
}
delay.delay_ms(self.delay_ms);
for col_line in &mut self.cols {
col_line.set_high();
col_line.set_high().unwrap();
}
row_line.set_low();
row_line.set_low().unwrap();
}
}
}
@@ -120,15 +120,15 @@ fn main() -> ! {
writeln!(stdout, "Start").unwrap();
if let Some(p) = microbit::Peripherals::take() {
// Split GPIO
let mut gpio = p.GPIO.split();
let gpio = p.GPIO.split();
// Configure RX and TX pins accordingly
let tx = gpio.pin24.into_push_pull_output().downgrade();
let rx = gpio.pin25.into_floating_input().downgrade();
// Configure serial communication
let (mut tx, _) = serial::Serial::uart0(p.UART0, tx, rx, BAUD115200).split();
writeln!(tx, "");
writeln!(tx, "Init");
writeln!(tx, "").unwrap();
writeln!(tx, "Init").unwrap();
// Create delay provider
let mut delay = Delay::new(p.TIMER0);
@@ -179,10 +179,10 @@ fn main() -> ! {
[0, 1, 1, 1, 0],
];
writeln!(tx, "Starting!");
writeln!(tx, "Starting!").unwrap();
loop {
writeln!(tx, "I <3 Rust on the micro:bit!");
writeln!(tx, "I <3 Rust on the micro:bit!").unwrap();
leds.display(&mut delay, letter_I, 1000);
leds.display(&mut delay, heart, 1000);
leds.display(&mut delay, letter_U, 1000);

View File

@@ -116,7 +116,7 @@ If you have forgotten how to do this, try looking at [the cargo book][cargo].
``` rust
#![no_std]
extern crate panic_abort;
extern crate panic_halt;
fn main() {
}
@@ -141,8 +141,8 @@ neither the crt0 nor the rust runtime are available,
so even implementing `start` would not help us.
We need to replace the operating system entry point.
You could for example name a function after the default entry point,
which for linux is `_start`, and start that way.
You could for example name a function after the default entry point,
which for linux is `_start`, and start that way.
Note, you would also need to disable [name mangling][nm]:
``` rust
@@ -232,15 +232,16 @@ and cargo will automatically add `--target thumbv6m-none-eabi`.
### `src/main.rs`
``` rust
``` rust
#![no_std]
#![no_main]
extern crate panic_abort;
extern crate panic_halt;
extern crate microbit;
use cortex_m_rt::entry;
#[entry];
#[entry]
fn main() {
}
```
@@ -271,7 +272,8 @@ An easy way to implement this is to use an infinite loop.
#![no_std]
#![no_main]
extern crate panic_abort;
extern crate panic_halt;
extern crate microbit;
use cortex_m_rt::entry;

View File

@@ -1,8 +1,9 @@
[package]
name = "start"
version = "0.2.0"
version = "0.3.0"
edition = "2018"
[dependencies]
panic-abort = "~0.3"
microbit="~0.6"
panic-halt = "~0.2"
microbit="~0.8"
cortex-m-rt="~0.6"

View File

@@ -3,7 +3,7 @@
extern crate cortex_m_rt;
extern crate microbit;
extern crate panic_abort;
extern crate panic_halt;
use cortex_m_rt::entry;

View File

@@ -24,12 +24,13 @@ To read and write to the serial bus from your computer, you will need to configu
## Code
``` rust
use core::fmt::Write;
use microbit::hal::prelude::*;
use microbit::hal::serial;
use microbit::hal::serial::BAUD115200;
// -- snip --
if let Some(p) = microbit::Peripherals::take() {
let mut gpio = p.GPIO.split();
let gpio = p.GPIO.split();
// Configure RX and TX pins accordingly
let tx = gpio.pin24.into_push_pull_output().downgrade();
let rx = gpio.pin25.into_floating_input().downgrade();

View File

@@ -1,9 +1,10 @@
[package]
name = "hello"
version = "0.2.0"
version = "0.3.0"
edition = "2018"
[dependencies]
microbit="~0.6"
microbit="~0.8"
cortex-m-rt="~0.6"
cortex-m-semihosting="~0.3"
panic-semihosting = "~0.5"

View File

@@ -20,20 +20,20 @@ fn main() -> ! {
writeln!(stdout, "Start").unwrap();
if let Some(p) = microbit::Peripherals::take() {
// Split GPIO
let mut gpio = p.GPIO.split();
let gpio = p.GPIO.split();
// Configure RX and TX pins accordingly
let tx = gpio.pin24.into_push_pull_output().downgrade();
let rx = gpio.pin25.into_floating_input().downgrade();
// Configure serial communication
let (mut tx, _) = serial::Serial::uart0(p.UART0, tx, rx, BAUD115200).split();
write!(tx, "serial - start\r\n");
write!(tx, "serial - start\r\n").unwrap();
// Get row and column for display
let mut led = gpio.pin13.into_push_pull_output();
let _ = gpio.pin4.into_push_pull_output();
// Set row high (column starts low)
led.set_high();
led.set_high().unwrap();
// Write string with newline and carriage return
write!(tx, "serial - LED on\r\n");
write!(tx, "serial - LED on\r\n").unwrap();
}
panic!("End");
}

View File

@@ -1,10 +1,11 @@
[package]
name = "microbit"
version = "0.1.0"
name = "micro"
version = "0.2.0"
edition = "2018"
[dependencies]
cortex-m-rt="~0.6"
cortex-m-semihosting="~0.3"
panic-abort = "~0.3"
panic-halt = "~0.2"
panic-semihosting = "~0.5"
microbit="~0.6"
microbit="~0.8"

View File

@@ -1,7 +1,7 @@
#![no_std]
#![no_main]
extern crate panic_abort;
extern crate panic_halt;
extern crate cortex_m_rt as rt;
extern crate microbit;
@@ -16,7 +16,7 @@ use microbit::hal::serial::BAUD115200;
fn main() -> ! {
if let Some(p) = microbit::Peripherals::take() {
// Split GPIO
let mut gpio = p.GPIO.split();
let gpio = p.GPIO.split();
// Configure RX and TX pins accordingly
let tx = gpio.pin24.into_push_pull_output().downgrade();
let rx = gpio.pin25.into_floating_input().downgrade();

View File

@@ -1,7 +1,7 @@
#![no_std]
#![no_main]
extern crate panic_abort;
extern crate panic_halt;
extern crate cortex_m_rt as rt;
extern crate microbit;

View File

@@ -5,7 +5,7 @@
extern crate microbit;
extern crate cortex_m_rt as rt;
extern crate cortex_m_semihosting as sh;
extern crate panic_abort;
extern crate panic_halt;
use core::fmt::Write;
use rt::entry;
@@ -23,25 +23,25 @@ fn main() -> ! {
let mut delay = Delay::new(p.TIMER0);
// Configure display pins
let row1 = gpio.pin13.into_push_pull_output().downgrade();
let row2 = gpio.pin14.into_push_pull_output().downgrade();
let row3 = gpio.pin15.into_push_pull_output().downgrade();
let col1 = gpio.pin4.into_push_pull_output().downgrade();
let col2 = gpio.pin5.into_push_pull_output().downgrade();
let col3 = gpio.pin6.into_push_pull_output().downgrade();
let col4 = gpio.pin7.into_push_pull_output().downgrade();
let col5 = gpio.pin8.into_push_pull_output().downgrade();
let col6 = gpio.pin9.into_push_pull_output().downgrade();
let col7 = gpio.pin10.into_push_pull_output().downgrade();
let col8 = gpio.pin11.into_push_pull_output().downgrade();
let col9 = gpio.pin12.into_push_pull_output().downgrade();
let row1 = gpio.pin13.into_push_pull_output();
let row2 = gpio.pin14.into_push_pull_output();
let row3 = gpio.pin15.into_push_pull_output();
let col1 = gpio.pin4.into_push_pull_output();
let col2 = gpio.pin5.into_push_pull_output();
let col3 = gpio.pin6.into_push_pull_output();
let col4 = gpio.pin7.into_push_pull_output();
let col5 = gpio.pin8.into_push_pull_output();
let col6 = gpio.pin9.into_push_pull_output();
let col7 = gpio.pin10.into_push_pull_output();
let col8 = gpio.pin11.into_push_pull_output();
let col9 = gpio.pin12.into_push_pull_output();
// Configure RX and TX pins accordingly
let tx = gpio.pin24.into_push_pull_output().downgrade();
let rx = gpio.pin25.into_floating_input().downgrade();
let mut leds = led::Display::new(
row1, row2, row3, col1, col2, col3, col4, col5, col6, col7, col8, col9,
col1, col2, col3, col4, col5, col6, col7, col8, col9, row1, row2, row3,
);
let (mut tx, _) = serial::Serial::uart0(p.UART0, tx, rx, BAUD115200).split();
@@ -84,4 +84,4 @@ fn main() -> ! {
}
}
panic!("End");
}
}

View File

@@ -1,10 +1,11 @@
[package]
name = "serial"
version = "0.1.0"
version = "0.2.0"
edition = "2018"
[dependencies]
heapless="~0.3"
heapless="~0.5"
cortex-m-rt="~0.6"
cortex-m-semihosting="~0.3"
panic-semihosting = "~0.5"
microbit="~0.6"
microbit="~0.8"

View File

@@ -13,7 +13,7 @@ use sh::hio;
use microbit::hal::prelude::*;
use microbit::hal::serial;
use microbit::hal::serial::BAUD115200;
use microbit::nb::block;
use microbit::block;
#[entry]
fn main() -> ! {
@@ -21,16 +21,16 @@ fn main() -> ! {
writeln!(stdout, "Start").unwrap();
if let Some(p) = microbit::Peripherals::take() {
// Split GPIO
let mut gpio = p.GPIO.split();
let gpio = p.GPIO.split();
// Configure RX and TX pins accordingly
let tx = gpio.pin24.into_push_pull_output().downgrade();
let rx = gpio.pin25.into_floating_input().downgrade();
// Configure serial communication
let (mut tx, mut rx) = serial::Serial::uart0(p.UART0, tx, rx, BAUD115200).split();
writeln!(tx, "Start");
writeln!(tx, "Start").unwrap();
loop {
let val = block!(rx.read()).unwrap();
block!(tx.write(val));
block!(tx.write(val)).unwrap();
}
}
panic!("End");

View File

@@ -1,18 +1,17 @@
# macOS
> UNTESTED: please submit an issue if you can confirm this works.
All the tools can be install using [Homebrew]:
[Homebrew]: http://brew.sh/
``` shell
$ brew cask install gcc-arm-embedded
$ brew cask install https://raw.githubusercontent.com/Homebrew/homebrew-cask/b88346667547cc85f8f2cacb3dfe7b754c8afc8a/Casks/gcc-arm-embedded.rb
$ brew install minicom openocd
```
If the `brew cask` command doesn't work (`Error: Unknown command: cask`), then run `brew tap
Caskroom/tap` first and try again.
Unfortunately gcc-arm-embedded has been [removed from Homebrew casks] in an attempt to force somebody to move it to Homebrew, and so it has to be installed using the cask in an earlier commit.
[removed from Homebrew casks]: https://github.com/Homebrew/homebrew-cask/pull/56802
That's all! Go to the [next section].

View File

@@ -38,18 +38,12 @@ Next, follow OS-agnostic installation instructions for a few of the tools:
Install rustup by following the instructions at [https://rustup.rs](https://rustup.rs).
Then, install or switch to the nightly channel.
``` shell
$ rustup default nightly
```
**NOTE** Make sure you have a nightly newer than `nightly-2018-10-12`.
**NOTE** Make sure you have a recent version, but only `1.39.0` is validated.
`rustc -V` should return a date newer than the one shown below:
``` shell
$ rustc -V
rustc 1.31.0-nightly (2c2e2c57d 2018-10-12)
rustc 1.39.0 (4560ea788 2019-11-04)
```
### OS specific instructions