mirror of
https://github.com/tillitis/tillitis-key1.git
synced 2025-06-26 15:10:36 -04:00
Handle reset info in reset syscall
Disabling debug printouts to get firmware to fit in ROM
This commit is contained in:
parent
ba211212f0
commit
e4028d9a86
2 changed files with 9 additions and 1 deletions
|
@ -524,6 +524,7 @@ int main(void)
|
||||||
|
|
||||||
// TODO Remove
|
// TODO Remove
|
||||||
// Wait for terminal program and a character to be typed
|
// Wait for terminal program and a character to be typed
|
||||||
|
/*
|
||||||
enum ioend endpoint = IO_NONE;
|
enum ioend endpoint = IO_NONE;
|
||||||
uint8_t available = 0;
|
uint8_t available = 0;
|
||||||
uint8_t in = 0;
|
uint8_t in = 0;
|
||||||
|
@ -537,6 +538,7 @@ int main(void)
|
||||||
// read failed! I/O broken? Just redblink.
|
// read failed! I/O broken? Just redblink.
|
||||||
assert(1 == 2);
|
assert(1 == 2);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
// TODO end of remove block
|
// TODO end of remove block
|
||||||
|
|
||||||
|
@ -556,7 +558,7 @@ int main(void)
|
||||||
|
|
||||||
// TODO Just start something from flash without looking in
|
// TODO Just start something from flash without looking in
|
||||||
// FW_RAM.
|
// FW_RAM.
|
||||||
state = FW_STATE_LOAD_FLASH;
|
//state = FW_STATE_LOAD_FLASH;
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
switch (state) {
|
switch (state) {
|
||||||
|
|
|
@ -7,15 +7,18 @@
|
||||||
#include <tkey/assert.h>
|
#include <tkey/assert.h>
|
||||||
#include <tkey/debug.h>
|
#include <tkey/debug.h>
|
||||||
#include <tkey/led.h>
|
#include <tkey/led.h>
|
||||||
|
#include <tkey/lib.h>
|
||||||
|
|
||||||
#include "partition_table.h"
|
#include "partition_table.h"
|
||||||
#include "storage.h"
|
#include "storage.h"
|
||||||
|
|
||||||
|
#include "../tk1/resetinfo.h"
|
||||||
#include "../tk1/syscall_num.h"
|
#include "../tk1/syscall_num.h"
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
static volatile uint32_t *system_reset = (volatile uint32_t *)TK1_MMIO_TK1_SYSTEM_RESET;
|
static volatile uint32_t *system_reset = (volatile uint32_t *)TK1_MMIO_TK1_SYSTEM_RESET;
|
||||||
static volatile uint32_t *udi = (volatile uint32_t *)TK1_MMIO_TK1_UDI_FIRST;
|
static volatile uint32_t *udi = (volatile uint32_t *)TK1_MMIO_TK1_UDI_FIRST;
|
||||||
|
static volatile uint8_t *resetinfo = (volatile uint8_t *) TK1_MMIO_RESETINFO_BASE;
|
||||||
// clang-format on
|
// clang-format on
|
||||||
|
|
||||||
extern struct partition_table part_table;
|
extern struct partition_table part_table;
|
||||||
|
@ -25,7 +28,10 @@ int32_t syscall_handler(uint32_t number, uint32_t arg1, uint32_t arg2,
|
||||||
{
|
{
|
||||||
switch (number) {
|
switch (number) {
|
||||||
case TK1_SYSCALL_RESET:
|
case TK1_SYSCALL_RESET:
|
||||||
|
// TODO: Take length from user
|
||||||
|
memcpy((uint8_t *)resetinfo, (uint8_t *)arg1, sizeof(struct reset));
|
||||||
*system_reset = 1;
|
*system_reset = 1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
case TK1_SYSCALL_ALLOC_AREA:
|
case TK1_SYSCALL_ALLOC_AREA:
|
||||||
if (storage_allocate_area(&part_table) < 0) {
|
if (storage_allocate_area(&part_table) < 0) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue