Skip to content

Commit

Permalink
Try to fix some formatting, spelling, and gramar.
Browse files Browse the repository at this point in the history
(my markdown editor and github don't quite agree on rendering)
  • Loading branch information
WestfW committed Sep 26, 2018
1 parent 8254eba commit 946fcee
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 25 deletions.
1 change: 1 addition & 0 deletions Wiki/Home.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
Welcome to the optiboot wiki!<br>

##Wiki pages:##

* [InstallingOnChips](https://github.com/Optiboot/optiboot/blob/master/Wiki/InstallingOnChips.md) - loading Optiboot onto chips, using various tools.
Expand Down
41 changes: 16 additions & 25 deletions Wiki/Virtual-Boot-Partition.md
Original file line number Diff line number Diff line change
@@ -1,44 +1,35 @@
# Virtual Boot Partition

1. What is a "Virtual Boot Partition"?

VIRTUAL\_BOOT\_PARTITION (VBP in short) is a hack for implementing a bootloader on parts that don't have "start at the bootloader address after reset" support. Sometimes it could be useful for normal chips when changing or messing with fuses is impossible or not desired.
1. What is a "Virtual Boot Partition"?<br>
VIRTUAL\_BOOT\_PARTITION (VBP for short) is a hack for implementing a bootloader on parts that don't have "start at the bootloader address after reset" support. Sometimes it could be useful for normal chips when changing or messing with fuses is impossible or not desired.

1. How it works?

1. How does it work?<br>
During programming bootloader "cleverly substitutes" start vector of application (located at address 0) by jump to bootloader. This way bootloader is always run after reset.

1. But how bootloader knows where application starts?

1. How does the bootloader know where the application starts?<br>
Bootloader assumes that start of application is typical vector table generated by most compilers. When Optiboot change start vector, it saves original jump to another free vector. Typically it uses SPM_RDY vector, or WDT if SPM_RDY is unavailable.

1. I have chip without SPM_RDY and I need to use WDR vector in my code.

1. I have chip without SPM_RDY and I need to use WDR vector in my code.<br>
It's possible to assign arbitrary vector using additional option to CFLAGS: `-Dsave_vect_num=xxx` where xxx could be name of vector like `EE_RDY_vect_num` (see virboot8 target in Makefile) or even just number (see attiny84 target in Makefile.extras). In fact, any number could be used, even outside vector table. There is only one limitation: it **MUST** be located in first flash page!

1. I don't use vector table. Can I use it anyway?

Yes, as long as first instruction is **jmp** on chips with more than 8KB memory or **rjmp** on smaller memory devices. You must also provide another jump to store old jump by Optiboot.

1. I don't use a vector table. Can I use it anyway?<br?
Yes, as long as first instruction is **jmp** on chips with more than 8KB memory or **rjmp** on smaller memory devices. You must also provide another jump to store old jump by Optiboot.<br>
It could be done for example by adding `-Dsave_vect_num=1` to CFLAGS during compiling bootloader, and making beginning of application like this:

~~~~
rjmp app
rjmp nowhere
app:
... ;your code here
~~~~

1. I want to add VBP to chip XXX

Check Makefile targets **virboot8**, **virboot328** or **attiny84** for examples.

There are 2 things required:
* add `-DVIRTUAL_BOOT_PARTITION` to CFLAGS
* adjust (decrease) address in **.text** part of LDSECTIONS (for example in `--section-start=.text=0x1c00`) to fit larger bootloader in memory

1. Any downsides of this feature?
1. I want to add VBP to chip XXX<br>
Check Makefile targets **virboot8**, **virboot328** or **attiny84** for examples.<br>
There are 2 things required:<br>
Add `-DVIRTUAL_BOOT_PARTITION` to CFLAGS<br>
Adjust (decrease) address in **.text** part of LDSECTIONS (for example in `--section-start=.text=0x1c00`) to fit larger bootloader in memory.

1. Any downsides of this feature?<br>
Sadly, there are 2 of them:
* Bootloader code is larger and doesn't fit in 512B
* It requres one unused vector to store original jump to application. And you must be sure that this vector will be unused by applications loaded by Optiboot with VBP enabled.
<br>The Bootloader code is larger and doesn't fit in 512B.
<br>It requres one unused vector to store original jump to application. And you must be sure that this vector will be unused by applications loaded by Optiboot with VBP enabled.

0 comments on commit 946fcee

Please sign in to comment.