1
0
mirror of https://github.com/elua/elua.git synced 2025-01-08 20:56:17 +08:00

1031 Commits

Author SHA1 Message Date
Bogdan Marinescu
d190763c7c added board EK-LM3S9D92 from TI (LM3S9D92) 2012-06-27 00:45:04 +03:00
Bogdan Marinescu
5a26274a6e WOFS documentation, last part + another style change 2012-06-27 00:34:58 +03:00
Bogdan Marinescu
df85a35a44 WOFS documentation, part II + a small style change 2012-06-26 13:27:15 +03:00
Bogdan Marinescu
c5f3033fb2 WOFS documentation, part I 2012-06-26 01:13:26 +03:00
Bogdan Marinescu
b705904ecd fixed compilation when BUILD_WOFS is not defined 2012-06-26 01:00:56 +03:00
Bogdan Marinescu
6877890892 renamed INTERNAL_FLASH_BLK_SIZE to INTERNAL_FLASH_UNIT_SIZE 2012-06-26 01:00:32 +03:00
Bogdan Marinescu
c2227a7645 fixed check for remaining size on WOFS 2012-06-26 00:57:55 +03:00
Bogdan Marinescu
a9ebeac525 WOFS fix: at most one file opened in write mode
Due to the nature of WOFS, at most one file can be opened on WOFS
in write mode at any given time.
2012-06-25 20:32:29 +03:00
Bogdan Marinescu
e35df54fda Fixed WOFS compilation on sim (Linux) 2012-06-25 10:50:32 +03:00
Bogdan Marinescu
e9a24cac11 Added WOFS + other stuff
This should really be more than one commit, but I wrote everything in one
shot and I don't feel like arranging the changes logically into different
commits. So, these are the changes:

- added WOFS (Write Once File System). This is a writeable file system that
  exists in the MCU's internal Flash memory and allows files to be written,
  but only once, in a single shot. More details to follow.
- the platform interface has a new MCU flash access interface.
- added WOFS "reference implementations" for two CPUs: LM3S8962 and
  STM32F103RE. They are easily extendable to other CPUs in the same platform
  and can be taken as a model for other platforms.
- the ROMFS file layout in memory was slightly changed.
- the simulator (src/platform/sim) got a new function (lseek).
- shell: now each shell command receives its arguments in a C-main-style
  (argc, argv) pair. This was originally Marcelo's idea and it finally
  made it to the master (although this particular implementation is mine),
  after I got fed up with all the argument parsing in the shell functions.
- new shell command: wofmt ("formats" a WOFS, effectively clearing it).
- a couple of small fixes in the shell code
2012-06-24 23:07:32 +03:00
Bogdan Marinescu
a378b8943e shell: multiple fixes
1. the filename for 'recv <filename>' was not set correctly
2. error messages for 'cp' were not always correct
3. check for copy errors and issue a message accordingly
2012-06-21 00:20:58 +03:00
Bogdan Marinescu
01a8dcd9a5 Changed the ROMFS terminator char
The ROMFS termination char is now 0xFF instead of 0x00 (in preparation
of WOFS).
2012-06-19 16:21:14 +03:00
Bogdan Marinescu
ed54aec47a Added FS registration data as argument to all FS functions
All the functions that implement a FS receive the instance data
of the FS (given at registration time to dm_register) as their
last argument. ROMFS was changed to take advantage of this.
2012-06-19 00:51:56 +03:00
Bogdan Marinescu
a199d47615 Changed FS registration mechanism
Now it's possible to have more than one instance of a given file
system. For example, one could use more that one ROM file system
in different physical locations (a possible configuration is
internal Flash and external serial memories). This mechanism is
currently implemented only in the device manager (devman.c),
actual instance implementation require per-FS support (to be
implemented later).
2012-06-17 14:04:51 +03:00
Nuccio Raciti
fc57957f7a Fixed the configuration file in order to work with the web builder
Signed-off-by: Nuccio Raciti <raciti.nuccio@gmail.com>
2012-06-15 17:47:43 +02:00
Bogdan Marinescu
2658f7cf77 Fixed timer counting direction on all platforms
On some platforms, the hardware timers were counting down instead
of up, which broke the assumptions of the new timer implementation.
Fixed by inverting the timer value (relative to its maximum value).
2012-05-26 00:45:18 +03:00
Bogdan Marinescu
d54659b572 RAM optimizations: pseudo RO strings, functions in Flash
This patch adds more RAM optimizations to eLua:

- direct file memory mapping: files in ROMFS will be read directly from Flash,
  without allocating any additional buffers. This doesn't help with RAM
  consumption in itself, but enables the set of optimizations below.

- pseudo read-only strings. These are still TStrings, but the actual string
  content can point directly to Flash. Original Lua strings are kept in
  TStrings structures (lobject.h):

  typedef union TString {
    L_Umaxalign dummy;  /* ensures maximum alignment for strings */
    struct {
      CommonHeader;
      lu_byte reserved;
      unsigned int hash;
      size_t len;
    } tsv;
  } TString;

  The actual string content comes right after the union TString above.
  Pseudo RO strings have the same header, but instead of having the string
  content after TString, they have a pointer that points to the actual
  string content (which should exist in a RO memory (Flash) that is directly
  accesbile from the MCU bus (like its internal Flash memory)). lua_newlstr
  detects automatically if it should create a regular string or a pseudo RO
  string by checking if the string pointer comes from the Flash region of the
  MCU. This optimization works for both precompiled (.lc) files that exist in
  ROMFS and for internal Lua strings (C code).

- functions in Flash: for precompiled (.lc) files that exist in ROMFS, the code
  of the functions and a part of the debug information will be read directly
  from Flash.

- ROMFS was changed to support files that are larger than 2**16 bytes and it
  aligns all its files to an offset which is a multiple of 4 in order to prevent
  data alignment issues with precompiled Lua code.

- the Lua bytecode dumper was changed to align all the instructions in a Lua
  function and a part of the debug information to an offset which is a multiple
  of 4. This might slightly increase the size of the precompiled Lua file.

These changes were succesfully checked against the Lua 5.1 test suite.
These changes were tested in eLua on LM3S and AVR32.
2012-05-10 00:39:42 +03:00
Sokolov Yura
1a5b04e2c3 NaN packing for TValues
From the Lua Power Patches page:

"Use NaN packing for TValue on x86 to reduce memory usage
and tiny performance gain (same as in LuaJIT i2).
It's fully ABI compatible with standard Lua libraries.
On one test script memory consumption reduced from 28Mb
to 21Mb and performance improved about 3.5-5%"

Added support for big endian architectures and LTR compatibility.
2012-04-19 00:04:10 +03:00
Yuki Tamura
c8b89a46d9 Fix possible Lua stack corruption issue
luaD_checkstack could damage the stack, possibly making further
references to 'func' invalid. Fix this by using the information
inside the CallInfo structure instead of 'func'.
2012-04-19 00:01:47 +03:00
James Snyder
fbebb2949e Correct issues with remote indexing and catch incorrect calls for LuaRPC
helper_remote_index() contained an error which allowed for incorrect
calculation of the string length to be sent. This should now be
fixed. Additionally, read_cmd_call() did not check whether indexing
was successful at each step, we now check whether the indexed result
is callable or a table and attempt to provide an indication of the
type of error made by the user.
2012-03-26 20:56:12 -05:00
James Snyder
7771e05fb2 clean up trailing whitespace 2012-03-26 19:17:40 -05:00
Martin Guy
59f9a2616b Added documentation file for mizar32 rtc module
Forgot to git-add it in the previous commit. Oops.
2012-03-25 13:43:53 +02:00
Thiago Naves
edf5b7a5ff Merge pull request #10 from mwilbur/rpc-client
Fix CR->NL and NL->CR transations on linux
2012-03-22 12:11:59 -07:00
Matt Wilbur
800a94db16 Fix CR->NL and NL->CR transations on linux 2012-03-22 10:12:51 -04:00
Martin Guy
6dd64a0dc6 New mizar32.rtc platform module
Methods: mizar32.rtc.get() returns a table like Lua's os.date()
and os.time() with fields year, monthm day, wday, hour min, sec
and mizar32.rtc.set() takes a similar table, only changing the
fields that are present in the table.
Works with DS1337 and PCF8563 clock chips.
2012-03-19 23:49:39 +01:00
Martin Guy
939cdbc3fd Convert AVR32 i2c_{send,recv} to take 7-bit addresses 2012-03-19 15:01:59 +01:00
Martin Guy
42af821686 AVR32 bugfix: Include usb-cdc.c in the Lua build system too. 2012-03-19 14:16:58 +01:00
Martin Guy
976d0f5111 Refactor AVR32 I2C code to have I2C packet-level send() and recv() routines
This introduces i2c_send() and i2c_recv in the AVR32 code that send/receive
whole I2C messages from start to optional stop.
2012-03-19 12:45:59 +01:00
Martin Guy
8b0bb4bbb9 Ensure Mizar32 i2c pins are initialized if i2c.setup() is not called 2012-03-19 12:12:29 +01:00
Martin Guy
374a21f15e Bug fix: always return 0 from Lua functions
Many mizar32.lcd() Lua functions used to tail-call the i2c_send_command()
functions, whereas they should explicitly return 0, the number of return
values from the Lua function. OK, i2c_send_command did return 0 but this
will change in future when it can detect slave presence and collisions.
2012-03-19 11:45:00 +01:00
Martin Guy
49ab7be03e Fix typo in docs 2012-03-15 09:20:57 +01:00
Martin Guy
5b141dd63b .gitignore: Ignore auto-generated file inc/git_version.h 2012-03-15 09:19:44 +01:00
Martin Guy
27da495151 Document pio.decode() 2012-03-08 21:23:13 +01:00
Martin Guy
ff2ba18585 Fix typos in PIO refman 2012-03-08 20:47:26 +01:00
Martin Guy
f9c3f2bf1c AVR32: In pio.decode(), reverse the mapping of hardware pins to PX names
On AVR32UC3A0 parts, the GPIO pins are named PA0-31, PB0-31, PC0-5 and
PX0-39. There is no port X: these pins map to five backwards ranges of
bits in the third and fourth sets of GPIO registers (where PC0-5 are
the first six of the third register set).
Already we map pio.PX_nn names to these values, and this commit puts the
reverse mapping into place in pio.decode().

Test program to verify correct mapping:

function eval(s)
  return( loadstring( "return(" .. s .. ")" ) )()
end

for i=0,39 do
  name = "pio.PX_" .. tostring(i)
  gpio = eval(name)
  print( name, gpio, pio.decode(gpio) )
end
2012-03-08 20:36:35 +01:00
James Snyder
f3e0620c98 Merge branch 'include_git_rev' 2012-03-08 12:07:56 -06:00
Martin Guy
90897d2d02 Save 4 bytes RAM per structure by reordering struct members
Structure size is 12 byte instead of 16 with GCC on x86,
probably also on others.
2012-02-26 04:14:53 +01:00
Martin Guy
55b78b50ac Build system changes to allow building with UIP_CONF_IPV6
These changes allow you to "#define UIP_CONF_IPV6 1" in uip-conf.h
for an IPV6-capable network layer.
This also removes a pointless inclusion in avr32/uip-conf.h
The changes to the other three .c files (from "build.h" to "platform_conf.h")
are just orthogonal future-proofing.
2012-02-19 18:25:37 +01:00
Martin Guy
35861a2d3d Restore original licence on uip-conf.h
Luminary Micros replaced the original permissive Swedish Institute
of Computer Science licence with their own one restricting it to
use on LM devices only. This put the original license back.
See http://uip-stack.cvs.sourceforge.net/viewvc/uip-stack/uip/unix/uip-conf.h
2012-02-19 18:05:52 +01:00
Martin Guy
37bc042bda Fix indentation 2012-02-19 11:35:59 +01:00
Martin Guy
406cfac9c9 AVR32: Defer SPI clock setup to when platform_spi_setup() is called
This change defers enabling the SPI clocks to platform_spi_setup()
so that, if SPI ports are not used and BUILD_MMCFS is disabled,
power consumption is reduced.
2012-02-19 10:35:11 +01:00
Martin Guy
1f94b2fab4 Remove unused declaration for a nonexistent function 2012-02-19 09:19:31 +01:00
Martin Guy
d2f5032d63 Remove uart.SYS_TIMER and net.SYS_TIMER (use tmr.SYS_TIMER)
This change removes the extra undocumented uart.SYS_TIMER and
net.SYS_TIMER constants, which are equal to tmr.SYS_TIMER.
The documentation says to use tmr.SYS_TIMER and in the rare case
of uart or net being compiled in but not tmr, the system timer
can be had by using nil or omitting the parameter.
2012-02-18 14:40:50 +01:00
James Snyder
28d44765c3 Merge branch 'master' into newsite 2012-02-07 15:01:54 -06:00
Martin Guy
6ed4b5208e Another fix in the CRLF handler: don't drop the second one of repeated
newline characters.

The console used to drop the second one of repeated \r or \n characters
because it would stash the second one in std_prev_char, then at the start
of the next call to std_read(), would poke the \r into the start of the
line buffer, returning a line that began with \r or \n.
This change processes the lookahead character the same as regular ones.
2012-02-07 12:55:14 +01:00
Martin Guy
640f9b970e Echo the lookahead character on console input
Previously, when pasting multiple lines into the console, the first
character of half the lines would not be echoed.  This was due to it being
slurped up by the CRLF lookahead detector, but not being echoed when it was
regurgitated. This change fixes that.
2012-02-07 12:34:05 +01:00
Martin Guy
c819565ebb Add missing constant uart.FLOW_NONE when optram==0
and reorder the optram=0 constants to match the optram>0 ones so that
it is more obvious to the eye whether they correspond or not.
2012-02-05 10:24:45 +01:00
Martin Guy
be9c9e46a7 Fix removal of UART buffer with uart.set_buffer(id, 0)
Previously, if you removed a buffer from e uart, the buffer was
removed but the interrupt routine was left intalled, which made
the interpreter hang if you typed a character on the serial port.
Now you can enable and disable UART buffers.

This also changes the order of interrupt handler to
- install the handler
- enable the interrupt
instead of the other way round, so there is no window of time with the
interrupt enabled but no handler installed.
2012-02-01 21:33:22 +01:00
Martin Guy
005d783c14 Bug fix: Allow more than one call to uart.set_buffer()
Previously, every call except the first one to uart.set_buffer()
with a buffer size > 0 would fail, as platform_cpu_set_int() returns
whether it used to be enabled or not, which is 0 the first time
(which happens to == PLATFORM_INT_OK) but 1 every time after that.
This change makes 0 and 1 success; all failure values are negative
so that people can now change UART buffer sizes.
2012-02-01 21:19:27 +01:00
Martin Guy
fe8b1d8630 Rework Mizar32 config so that UART buffering is still available
The usb-cdc config removed UART buffering completely, whereas
it should still be available via uart.set_buffer().
2012-02-01 18:56:33 +01:00