Harald Welte
8adf0ac2ce
DFU app: call into board_main_top() for qmod related initialization
2017-03-03 01:52:34 +01:00
Harald Welte
f415d7163b
Call USBD_Disconnect before software-triggered CPU reset
...
This makes sure that we'll re-enumerate on the USB, as a CPU reset
apparently doesn't automatically release the pull-up and notify the hub
that we were gone?
2017-03-03 01:51:43 +01:00
Harald Welte
ec0837c463
change from \r\n (CRLF) to \n\r (LFCR)
...
For some strange reason my output is garbled in both the 'screen' and
'cu' teerminal programs and 'raw' terminal (stty) mode. I fail to
understand why, but let's simply adjust the code as needed for now.
2017-03-03 01:33:24 +01:00
Harald Welte
0de99cd069
DFU: String descriptors for DFU alt-interfaces
...
they are only shown in DFU mode for now, until we find a way to export
them over to the runtime.
2017-03-03 01:20:19 +01:00
Harald Welte
ac4f66e5d1
DFU: Set 10ms bwPollTimeout (lowest possible as per spec)
2017-03-03 01:13:34 +01:00
Harald Welte
91fc40240e
DFU: make sure to properly initialize g_dfu pointer before using it
2017-03-03 01:05:22 +01:00
Harald Welte
b04f4f0ee8
DFU Runtime: Add missing return after handling USB standard requests
...
the same as 479e97e338 but this time for
the runtime, not for DFU.
2017-03-03 00:36:39 +01:00
Harald Welte
e8eea29cf6
dfu: fix cosmetic issue in debug message
2017-03-03 00:35:51 +01:00
Harald Welte
d1e963479e
DFU: fix transitions between runtime and DFU mode
...
we now always go through a processor reset to avoid any state that might
be persistent/left-over during the switch.
2017-03-03 00:34:17 +01:00
Harald Welte
db17e83960
cstartup: (re-)enable interrupts before calling main()
2017-03-02 23:19:13 +01:00
Harald Welte
ec9b5fff3f
dfu/main.c: Initialize FLASHD driver before using it
2017-03-02 23:18:40 +01:00
Harald Welte
0af4948211
cstartup / USBD: Use correct Makefile conditionals for DFU
2017-03-02 23:18:02 +01:00
Harald Welte
adbe72a5ba
Makefile: Define APPLICATION_foo BOARD_bar and ENVIRONMENT_baz #defines
...
This can help us with conditional code
2017-03-02 23:16:01 +01:00
Harald Welte
e36970cac7
dfu: print Chip ID during boot
2017-03-02 19:24:14 +01:00
Harald Welte
cab66419d6
flashd: Set 6 Wait states as per Errata requiremens for Revision A
...
It is utterly unacceptable that Atmel is shipping example code in 2011,
which doesn't support parts that are shipped still in 2016. They would
have had five years to fix their code to implement the chip errata :(
2017-03-02 19:22:50 +01:00
Harald Welte
479e97e338
DFU: Add missing 'return' after handling generic USB control request
2017-03-02 16:53:13 +01:00
Harald Welte
203abf5f6e
dfu_desc: Add some string descriptors and fix configuration desc table
2017-03-02 16:52:48 +01:00
Harald Welte
ee9ebb30da
stdio: Increase max string size to 512 and don't endless-loop!!
2017-03-02 16:52:08 +01:00
Harald Welte
b2ad7f76a1
dfu_des.c: Cosmetic changes, use named initializers
2017-03-01 22:15:28 +01:00
Harald Welte
0395bd15b3
move PLLB (for USB) initialization to board_lowlevel.c
...
This way it is present both inside the DFU loader and in the main app.
2017-02-28 01:28:56 +01:00
Harald Welte
c430ac1f2a
have local stdio.h file to avoid newlib issues
...
... we should move to -nostdinc at some point :/
2017-02-28 01:25:12 +01:00
Harald Welte
adba0ce80b
fix g_dfu access from both DFU and runtime access
...
We need to refer to g_dfu as a pointer from all code. In DFU mode, it
gets assigned to the address of _g_dfu, which is placed by the linker
script at the start of RAM. In runtime mode, the pointer is statically
defined to point at the start of RAM. The linker script for the runtime
(dfu environment) is adjusted to save the first 32 bytes for the _g_dfu
structure.
2017-02-28 01:10:32 +01:00
Harald Welte
65cca7cccc
ensure g_dfu is linked to start of RAM when building DFU loader
2017-02-28 01:10:27 +01:00
Harald Welte
db30727514
remove obsolete old linker script
2017-02-28 01:10:27 +01:00
Harald Welte
32852bc1d9
DFU: towards a more complete implementation
...
* we now actually route the EP0 control requests in DFU mode to the
correct handler (weak linker symbols are tricky)
* we now actually call code to read/write data from/to RAM/FLASH
2017-02-28 01:10:23 +01:00
Harald Welte
edf9c9d322
Makefile: Optimize for size
...
This gets the dfu image down from 19 to 11 kBytes, with is well within
the 16kbyte limit for the DFU partition.
2017-02-27 23:24:22 +01:00
Harald Welte
37b6e41f84
move last few files from src_board / include_board
2017-02-27 23:20:38 +01:00
Harald Welte
964f509f59
remove pio_capture, we don't use it
...
As it registers a non-weak exception handler, it consumes memory in
every build
2017-02-27 23:14:16 +01:00
Harald Welte
96e62a4664
stdio.c: fix compiler warning
2017-02-27 23:05:15 +01:00
Harald Welte
045ea3eb7b
timer.h: Fix compiler warnings about redefinition
2017-02-27 23:02:26 +01:00
Harald Welte
d09829dcc6
Remove newlib dependency, include own stdio/string/assert
2017-02-27 23:00:26 +01:00
Harald Welte
d52523185f
fix some compiler warnings
2017-02-27 22:18:47 +01:00
Harald Welte
d8a003dfd7
Structure build system to build for multiple boards/apps/environments
2017-02-27 22:18:45 +01:00
Harald Welte
a1cd0f31c8
fix compilation of card_emu_tests
2017-02-27 14:29:07 +01:00
Harald Welte
3f5e3ddffc
Change directory structure to align with Atmel softpack
...
This way we can easily check with 'diff' for differences in our code and
Atmel softpack. Also, this layout is more suitable for building various
different firmware images (e.g. factory-test, dfu-loader, main
application) for a variety of different boards (simtrace, owhw, qmod).
2017-02-27 14:24:11 +01:00
Harald Welte
7ed6f3bc37
WIP: Introduce USB DFU code from my at91lib DFU port
2017-02-27 09:28:34 +01:00
Harald Welte
aa3b867abb
WIP: split main from board-speciic parts
2017-02-26 15:59:56 +01:00
Harald Welte
a05ccc9103
build efc.o and flashd.o as part of build process
2017-02-26 15:51:10 +01:00
Harald Welte
e9eaf90d35
import efc.[ch] and flashd.[ch] from SAM3S softpack 2.1
2017-02-26 12:52:01 +01:00
Harald Welte
1d91058eee
qmod: Inver initial state of PERST signals
...
The signals are driving an external NPN transistor, so the default state
must be low at reset to en sure that !PERST on the modem input is
de-asserted by default.
2017-02-10 19:50:24 +01:00
Harald Welte
4a9bce127f
qmod: invert WWAN_PERST logic (we use transistors now)
2017-02-10 19:19:52 +01:00
Harald Welte
6732248f71
Add support for board version reading via ADC
2017-02-10 19:19:48 +01:00
Harald Welte
9c78cff10b
Extend WWAN modem PERST to 300ms
...
It seems like a lot of modems have rather long (100ms!) minimum reset
durations. Makes me wonder if it's an actual reset line or rather juts
some GPIO that they poll/sample every so often. Then there are other
modems that state the reset *must not* be longer than 1s. So let's
choose 300ms as a value in-between.
2017-02-04 14:58:49 +01:00
Harald Welte
987f59aa02
Import libosmocore timer infrastructure and use it for PERST
...
The PERST is thus no longer busy-waiting but starting a timer to release
the PERST after 1ms.
2017-02-04 14:58:45 +01:00
Harald Welte
b41598b602
Introudce an include_libosmocore directory and move (updated) linuxlist there
2017-02-04 12:15:58 +01:00
Harald Welte
7e5c7d5b82
Add debug commands '1' and '2' to generate 1ms reset pulses to modems
2017-02-03 22:59:04 +01:00
Harald Welte
31f817c3ac
Add support for controlling PERST of WWAN modems (on qmod)
2017-02-03 22:22:20 +01:00
Harald Welte
83207e0cad
Add 'mdelay()' function to busy-wait for given number of milli-seconds
2017-02-03 22:22:17 +01:00
Harald Welte
2819e9c131
wwan_led: Read + report status changes of WWAN LED inputs
2017-02-03 07:49:28 +01:00
Harald Welte
af6147997d
qmod: Remove 'U' debug command and directly initialize USB
...
The hack to manually delay the USB initialization is no longer needed as
finally the USB enumerates.
2017-01-12 18:59:41 +01:00