[En-Nut-Discussion] Ethernut on TI's Cortex-M3 (Stellaris LM3S...)

Philipp Burch phip at hb9etc.ch
Mon Oct 8 23:16:31 CEST 2012


Hi Ole, Uwe, everyone,

On 10/08/2012 12:08 PM, Ole Reinhardt wrote:
> [...]
> Unfortunately there was not much effort spent yet to support the LM3s
> series yet. So there is only a configuration file and a linker script
> yet.
>
> In general the kernel will start up on the LM3S, but only the kernel.
> Any device driver have to be written from scratch.
>
> I just though about doing this, but currently I could do this only as a
> commercial project, as my spare time is limited.
>
>> I suppose I'd need some assistance
>> for the latter option, as I've never done this before.
>
> I'd be happy to give you any assistance, wherever you need. I have two
> LM3S boards here, so I can also help you with debugging.
>[...]

I've now started to update the directory structure and the headers. 
Please find attached the Git bundle containing the changesets which I've 
made so far. I still need to get used to using Git, so never mind if a 
changeset may look weird or misses a file. My working copy is clean now, 
so at least the last changeset should include everything.
I'd greatly appreciate if someone could have a look at it and tell me if 
it is basically correct what I'm doing. And if it adheres to the 
Ethernut standards (if there are any).

And them something specifically @Ole:

Most parts of the headers are fairly self-explaining, but two locations 
confused me so far. Both are related to the clocking. The first one is 
the _clk.h (e.g. stm32_clk.h in nut/include/arch/cm3/stm):


/* STM32F Clock source selectors */
#define SYSCLK_HSI  0
#define SYSCLK_PLL  1
#define SYSCLK_HSE  2
#define PLLCLK_HSI  3
#define PLLCLK_HSE  4


What are these numbers for? Are they something STM32-related, or should 
these be present on all Cortex-M3? The other looks similar and is in 
nut/include/arch/cm3/timer.h:

#define NUT_HWCLK_EMC   2

/*!
  * Clock for USB
  */
#define NUT_HWCLK_USB   3

/*!
  * Clock for WDT
  */
#define NUT_HWCLK_WDT   4

... and so on

Again, what do these numbers stand for? This time it can't be specific 
to one single Cortex-M3 architecture, as it is in a generic file and the 
same defines are present for different families.

Generally: How is the clocking handled in Ethernut? Is there a document 
explaining this? I'd expect something like SetClock() to which I'd pass 
some params to define how the device is clocked, but this seems to be 
handled differently.

Thanks for your support,
Philipp


More information about the En-Nut-Discussion mailing list