Add battfs test dir.
authorbatt <batt@38d2e660-2303-0410-9eaa-f027e97ec537>
Tue, 5 Feb 2008 08:43:01 +0000 (08:43 +0000)
committerbatt <batt@38d2e660-2303-0410-9eaa-f027e97ec537>
Tue, 5 Feb 2008 08:43:01 +0000 (08:43 +0000)
git-svn-id: https://src.develer.com/svnoss/bertos/trunk@1087 38d2e660-2303-0410-9eaa-f027e97ec537

app/battfs/appconfig.h [new file with mode: 0644]
app/battfs/battfs_test.c [new file with mode: 0644]
app/battfs/battfs_test.mk [new file with mode: 0644]
app/battfs/verstag.h [new file with mode: 0644]
app/demo/appconfig.h [deleted file]
app/demo/battfs_test.c [deleted file]
app/demo/battfs_test.mk [deleted file]
app/demo/verstag.h [deleted file]

diff --git a/app/battfs/appconfig.h b/app/battfs/appconfig.h
new file mode 100644 (file)
index 0000000..4361d0f
--- /dev/null
@@ -0,0 +1,227 @@
+/**
+ * \file
+ * <!--
+ * This file is part of BeRTOS.
+ *
+ * Bertos is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ *
+ * As a special exception, you may use this file as part of a free software
+ * library without restriction.  Specifically, if other files instantiate
+ * templates or use macros or inline functions from this file, or you compile
+ * this file and link it with other files to produce an executable, this
+ * file does not by itself cause the resulting executable to be covered by
+ * the GNU General Public License.  This exception does not however
+ * invalidate any other reasons why the executable file might be covered by
+ * the GNU General Public License.
+ *
+ * Copyright 2003, 2004, 2006 Develer S.r.l. (http://www.develer.com/)
+ *
+ * -->
+ *
+ * \brief DevLib configuration options
+ *
+ * You should copy this header in your project and rename it to
+ * "config.h" and delete the CONFIG_ macros for the modules
+ * you're not using.
+ *
+ * <h2>Working with multiple applications</h2>
+ *
+ * If your project is made of multiple DevLib-based applications,
+ * create a custom "config.h" file in each application subdirectory
+ * and play with the compiler include path to get the desired result.
+ * You can share common options by creationg a "config_common.h" header
+ * and including it from all your "config.h" copies.
+ *
+ * <h2>Configuration style</h2>
+ *
+ * For improved compile-time checking of configuration options,
+ * the preferred way to use a \c CONFIG_ symbol is keeping it
+ * always defined with a value of either 0 or 1.  This lets
+ * you write tests like this:
+ *
+ * \code
+ *  #if CONFIG_FOO
+ *  void foo(void)
+ *  {
+ *      if (CONFIG_BAR)
+ *          bar();
+ *  }
+ *  #endif // CONFIG_FOO
+ * \endcode
+ *
+ * In most cases, we rely on the optimizer to discard checks
+ * on constant values and performing dead-code elimination.
+ *
+ * \version $Id$
+ * \author Bernardo Innocenti <bernie@develer.com>
+ * \author Stefano Fedrigo <aleph@develer.com>
+ */
+
+#ifndef APPCONFIG_COMMON_H
+#define APPCONFIG_COMMON_H
+
+/** kdebug console */
+#define CONFIG_KDEBUG_PORT 0
+
+
+/** Baud-rate for the kdebug console */
+#define CONFIG_KDEBUG_BAUDRATE  19200
+
+/**
+ * printf()-style formatter configuration.
+ *
+ * \sa PRINTF_DISABLED
+ * \sa PRINTF_NOMODIFIERS
+ * \sa PRINTF_REDUCED
+ * \sa PRINTF_NOFLOAT
+ * \sa PRINTF_FULL
+ */
+#define CONFIG_PRINTF PRINTF_FULL
+
+/**
+ * Multithreading kernel.
+ *
+ * \sa config_kern.h
+ */
+#define CONFIG_KERNEL 0
+
+/**
+ * \name Serial driver parameters
+ * \{
+ */
+       /** [bytes] Size of the outbound FIFO buffer for port 0. */
+       #define CONFIG_UART0_TXBUFSIZE  32
+
+       /** [bytes] Size of the inbound FIFO buffer for port 0. */
+       #define CONFIG_UART0_RXBUFSIZE  64
+
+       /** [bytes] Size of the outbound FIFO buffer for port 1. */
+       #define CONFIG_UART1_TXBUFSIZE  32
+
+       /** [bytes] Size of the inbound FIFO buffer for port 1. */
+       #define CONFIG_UART1_RXBUFSIZE  64
+
+       /** [bytes] Size of the outbound FIFO buffer for SPI port (AVR only). */
+       #define CONFIG_SPI_TXBUFSIZE    16
+
+       /** [bytes] Size of the inbound FIFO buffer for SPI port (AVR only). */
+       #define CONFIG_SPI_RXBUFSIZE    32
+
+       /** SPI data order (AVR only). */
+       #define CONFIG_SPI_DATA_ORDER   SER_MSB_FIRST
+
+       /** SPI clock division factor (AVR only). */
+       #define CONFIG_SPI_CLOCK_DIV    16
+
+       /** SPI clock polarity: 0 = normal low, 1 = normal high (AVR only). */
+       #define CONFIG_SPI_CLOCK_POL    0
+
+       /** SPI clock phase: 0 = sample on first edge, 1 = sample on second clock edge (AVR only). */
+       #define CONFIG_SPI_CLOCK_PHASE  0
+
+       /** Default transmit timeout (ms). Set to -1 to disable timeout support */
+       #define CONFIG_SER_TXTIMEOUT    -1
+
+       /** Default receive timeout (ms). Set to -1 to disable timeout support */
+       #define CONFIG_SER_RXTIMEOUT    -1
+
+       /** Use RTS/CTS handshake */
+       #define CONFIG_SER_HWHANDSHAKE   0
+
+       /** Default baud rate (set to 0 to disable) */
+       #define CONFIG_SER_DEFBAUDRATE   0
+
+       /** Enable ser_gets() and ser_gets_echo() */
+       #define CONFIG_SER_GETS          0
+
+       /** Enable second serial port in emulator. */
+       #define CONFIG_EMUL_UART1        0
+
+       /**
+        * Transmit always something on serial port 0 TX
+        * to avoid interference when sending burst of data,
+        * using AVR multiprocessor serial mode
+        */
+       #define CONFIG_SER_TXFILL        0
+
+       #define CONFIG_SER_STROBE        0
+/*\}*/
+
+/// Hardware timer selection for drv/timer.c
+#define CONFIG_TIMER  TIMER_ON_OUTPUT_COMPARE2
+
+/// Debug timer interrupt using a strobe pin.
+#define CONFIG_TIMER_STROBE  0
+
+/// Enable ADS strobe.
+#define CONFIG_ADC_STROBE  0
+
+/// Enable watchdog timer.
+#define CONFIG_WATCHDOG  0
+
+/// EEPROM type for drv/eeprom.c
+#define CONFIG_EEPROM_TYPE EEPROM_24XX256
+
+/// Select bitmap pixel format.
+#define CONFIG_BITMAP_FMT  BITMAP_FMT_PLANAR_V_LSB
+
+/// Enable line clipping algorithm.
+#define CONFIG_GFX_CLIPPING  1
+
+/// Enable text rendering in bitmaps.
+#define CONFIG_GFX_TEXT  1
+
+/// Enable virtual coordinate system.
+#define CONFIG_GFX_VCOORDS  1
+
+/// Keyboard polling method
+#define CONFIG_KBD_POLL  KBD_POLL_SOFTINT
+
+/// Enable keyboard event delivery to observers
+#define CONFIG_KBD_OBSERVER  0
+
+/// Enable key beeps
+#define CONFIG_KBD_BEEP  1
+
+/// Enable long pression handler for keys
+#define CONFIG_KBD_LONGPRESS  1
+
+/**
+ * \name Type for the chart dataset
+ * \{
+ */
+#define CONFIG_CHART_TYPE_X uint8_t
+#define CONFIG_CHART_TYPE_Y uint8_t
+/*\}*/
+
+/// Enable button bar behind menus
+#define CONFIG_MENU_MENUBAR  0
+
+/// Enable smooth scrolling in menus
+#define CONFIG_MENU_SMOOTH  1
+
+/// Size of block for MD2 algorithm.
+#define CONFIG_MD2_BLOCK_LEN 16
+
+/// Use standard permutation in MD2 algorithm.
+#define CONFIG_MD2_STD_PERM 0
+
+/// Define a size, in byte, of entropy pool.
+#define CONFIG_SIZE_ENTROPY_POOL 64
+
+/// Turn on or off timer support in Randpool.
+#define CONFIG_RANDPOOL_TIMER 1
+
+#endif /* APPCONFIG_H */
diff --git a/app/battfs/battfs_test.c b/app/battfs/battfs_test.c
new file mode 100644 (file)
index 0000000..a0b8e34
--- /dev/null
@@ -0,0 +1,131 @@
+/**
+ * \file
+ * <!--
+ * This file is part of BeRTOS.
+ *
+ * Bertos is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ *
+ * As a special exception, you may use this file as part of a free software
+ * library without restriction.  Specifically, if other files instantiate
+ * templates or use macros or inline functions from this file, or you compile
+ * this file and link it with other files to produce an executable, this
+ * file does not by itself cause the resulting executable to be covered by
+ * the GNU General Public License.  This exception does not however
+ * invalidate any other reasons why the executable file might be covered by
+ * the GNU General Public License.
+ *
+ * Copyright 2007 Develer S.r.l. (http://www.develer.com/)
+ *
+ * -->
+ *
+ * \version $Id: demo.c 18242 2007-10-08 17:35:23Z marco $
+ *
+ * \author Francesco Sacchi <batt@develer.com>
+ *
+ * \brief BattFs Test.
+ */
+
+#include <cfg/debug.h>
+#include <fs/battfs.h>
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+
+FILE *fp;
+const char test_filename[]="battfs_disk.bin";
+const char *filename;
+
+#define PAGE_SIZE 128
+static bool disk_open(struct BattFsSuper *d)
+{
+       fp = fopen(filename, "r+b");
+       ASSERT(fp);
+       fseek(fp, 0, SEEK_END);
+       d->page_size = PAGE_SIZE;
+       d->page_count = ftell(fp) / d->page_size;
+       d->disk_size = d->page_size * d->page_count;
+       d->page_array = malloc(d->page_count * sizeof(pgcnt_t));
+       TRACEMSG("page_size:%d, page_count:%d, disk_size:%d\n", d->page_size, d->page_count, d->disk_size);
+       return (fp && d->page_array);
+}
+
+static size_t disk_page_read(struct BattFsSuper *d, pgcnt_t page, pgaddr_t addr, void *buf, size_t size)
+{
+       TRACEMSG("page:%d, addr:%d, size:%d\n", page, addr, size);
+       fseek(fp, page * d->page_size + addr, SEEK_SET);
+       return fread(buf, 1, size, fp);
+}
+
+static size_t disk_page_write(struct BattFsSuper *d, pgcnt_t page, pgaddr_t addr, void *buf, size_t size)
+{
+       TRACEMSG("page:%d, addr:%d, size:%d\n", page, addr, size);
+       fseek(fp, page * d->page_size + addr, SEEK_SET);
+       return fwrite(buf, 1, size, fp);
+}
+
+static bool disk_page_erase(struct BattFsSuper *d, pgcnt_t page)
+{
+       TRACEMSG("page:%d\n", page);
+       fseek(fp, page * d->page_size, SEEK_SET);
+
+       for (int i = 0; i < d->page_size; i++)
+               if (fputc(0xff, fp) == EOF)
+                       return false;
+       return true;
+}
+
+static bool disk_close(struct BattFsSuper *d)
+{
+       TRACE;
+       free(d->page_array);
+       return (fclose(fp) != EOF);
+}
+
+int main(int argc, char *argv[])
+{
+       if (argc < 2)
+       {
+               FILE *fpt = fopen(test_filename, "w+");
+               for (int i = 0; i < 32768; i++)
+                       fputc(0xff, fpt);
+               fclose(fpt);
+               filename = test_filename;
+       }
+       else
+               filename = argv[1];
+
+       BattFsSuper disk;
+       disk.open = disk_open;
+       disk.read = disk_page_read;
+       disk.write = disk_page_write;
+       disk.erase = disk_page_erase;
+       disk.close = disk_close;
+
+       if (battfs_init(&disk))
+       {
+               kprintf("page_array:\n");
+               for (pgcnt_t i = 0; i < disk.page_count; i++)
+               {
+                       if (!(i % 16))
+                               kputchar('\n');
+                       kprintf("%04d ", disk.page_array[i]);
+               }
+               kputchar('\n');
+               return 0;
+       }
+       else
+               return 1;
+}
diff --git a/app/battfs/battfs_test.mk b/app/battfs/battfs_test.mk
new file mode 100644 (file)
index 0000000..5df84bf
--- /dev/null
@@ -0,0 +1,29 @@
+#
+# $Id: demo.mk 18234 2007-10-08 13:39:48Z rasky $
+# Copyright 2003, 2004, 2005, 2006 Develer S.r.l. (http://www.develer.com/)
+# All rights reserved.
+#
+# Makefile fragment for DevLib demo application.
+#
+# Author: Bernardo Innocenti <bernie@develer.com>
+#
+
+# Set to 1 for debug builds
+battfs_test_DEBUG = 1
+
+# Our target application
+TRG += battfs_test
+
+
+battfs_test_CSRC = \
+       fs/battfs.c \
+       app/battfs/battfs_test.c
+
+battfs_test_CFLAGS = -O0 -D'ARCH=ARCH_EMUL' -D_EMUL -Iapp/battfs -Ihw -g3
+
+
+# Debug stuff
+ifeq ($(battfs_test_DEBUG),1)
+       battfs_test_CFLAGS += -D_DEBUG
+endif
+
diff --git a/app/battfs/verstag.h b/app/battfs/verstag.h
new file mode 100644 (file)
index 0000000..d84efd2
--- /dev/null
@@ -0,0 +1,94 @@
+/**
+ * \file
+ * <!--
+ * This file is part of BeRTOS.
+ *
+ * Bertos is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ *
+ * As a special exception, you may use this file as part of a free software
+ * library without restriction.  Specifically, if other files instantiate
+ * templates or use macros or inline functions from this file, or you compile
+ * this file and link it with other files to produce an executable, this
+ * file does not by itself cause the resulting executable to be covered by
+ * the GNU General Public License.  This exception does not however
+ * invalidate any other reasons why the executable file might be covered by
+ * the GNU General Public License.
+ *
+ * Copyright 2003, 2004, 2005, 2006 Develer S.r.l. (http://www.develer.com/)
+ * Copyright 2001, 2002, 2003 by Bernardo Innocenti <bernie@codewiz.org>
+ *
+ * -->
+ *
+ * \version $Id$
+ *
+ * \author Bernardo Innocenti <bernie@develer.com>
+ *
+ * \brief Declare application version strings
+ */
+#ifndef DEVLIB_VERSTAG_H
+#define DEVLIB_VERSTAG_H
+
+#ifndef ARCH_CONFIG_H
+       #include "cfg/arch_config.h"
+#endif
+
+#define APP_NAME "Devlib Demo"
+#define APP_DESCRIPTION "DevLib Multidemo Application"
+#define APP_AUTHOR "Develer"
+#define APP_COPYRIGHT "Copyright 2006 Develer (http://www.develer.com/)"
+
+#define VERS_MAJOR 0
+#define VERS_MINOR 1
+#define VERS_REV   0
+#define VERS_LETTER ""
+
+/**
+ * If _SNAPSHOT is defined, \c VERS_TAG contains the build date
+ * date instead of a numeric version string.
+ */
+#define _SNAPSHOT
+
+#ifdef _DEBUG
+       #define VERS_DBG "D"
+#else
+       #define VERS_DBG ""
+#endif
+
+#define __STRINGIZE(x) #x
+#define _STRINGIZE(x) __STRINGIZE(x)
+
+/** Build application version string (i.e.: "1.7.0") */
+#define MAKE_VERS(maj,min,rev) _STRINGIZE(maj) "." _STRINGIZE(min) "." _STRINGIZE(rev) VERS_LETTER VERS_DBG
+#ifdef _SNAPSHOT
+       #define VERS_TAG "snapshot" " " __DATE__ " " __TIME__ " " VERS_LETTER " " VERS_DBG
+#else
+       #define VERS_TAG MAKE_VERS(VERS_MAJOR,VERS_MINOR,VERS_REV)
+#endif
+
+/** Build application version string suitable for MS windows resource files (i.e.: "1, 7, 0, 1") */
+#define MAKE_RCVERS(maj,min,rev,bld) _STRINGIZE(maj) ", " _STRINGIZE(min) ", " _STRINGIZE(rev) ", " _STRINGIZE(bld)
+#define RCVERSION_TAG MAKE_VERS(VERS_MAJOR,VERS_MINOR,VERS_REV)
+
+/** The revision string (contains VERS_TAG) */
+extern const char vers_tag[];
+
+/** Sequential build number (contains VERS_BUILD) */
+extern const int vers_build_nr;
+//extern const char vers_build_str[];
+
+/** Hostname of the machine used to build this binary (contains VERS_HOST) */
+extern const char vers_host[];
+
+#endif /* DEVLIB_VERSTAG_H */
diff --git a/app/demo/appconfig.h b/app/demo/appconfig.h
deleted file mode 100644 (file)
index 4361d0f..0000000
+++ /dev/null
@@ -1,227 +0,0 @@
-/**
- * \file
- * <!--
- * This file is part of BeRTOS.
- *
- * Bertos is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
- *
- * As a special exception, you may use this file as part of a free software
- * library without restriction.  Specifically, if other files instantiate
- * templates or use macros or inline functions from this file, or you compile
- * this file and link it with other files to produce an executable, this
- * file does not by itself cause the resulting executable to be covered by
- * the GNU General Public License.  This exception does not however
- * invalidate any other reasons why the executable file might be covered by
- * the GNU General Public License.
- *
- * Copyright 2003, 2004, 2006 Develer S.r.l. (http://www.develer.com/)
- *
- * -->
- *
- * \brief DevLib configuration options
- *
- * You should copy this header in your project and rename it to
- * "config.h" and delete the CONFIG_ macros for the modules
- * you're not using.
- *
- * <h2>Working with multiple applications</h2>
- *
- * If your project is made of multiple DevLib-based applications,
- * create a custom "config.h" file in each application subdirectory
- * and play with the compiler include path to get the desired result.
- * You can share common options by creationg a "config_common.h" header
- * and including it from all your "config.h" copies.
- *
- * <h2>Configuration style</h2>
- *
- * For improved compile-time checking of configuration options,
- * the preferred way to use a \c CONFIG_ symbol is keeping it
- * always defined with a value of either 0 or 1.  This lets
- * you write tests like this:
- *
- * \code
- *  #if CONFIG_FOO
- *  void foo(void)
- *  {
- *      if (CONFIG_BAR)
- *          bar();
- *  }
- *  #endif // CONFIG_FOO
- * \endcode
- *
- * In most cases, we rely on the optimizer to discard checks
- * on constant values and performing dead-code elimination.
- *
- * \version $Id$
- * \author Bernardo Innocenti <bernie@develer.com>
- * \author Stefano Fedrigo <aleph@develer.com>
- */
-
-#ifndef APPCONFIG_COMMON_H
-#define APPCONFIG_COMMON_H
-
-/** kdebug console */
-#define CONFIG_KDEBUG_PORT 0
-
-
-/** Baud-rate for the kdebug console */
-#define CONFIG_KDEBUG_BAUDRATE  19200
-
-/**
- * printf()-style formatter configuration.
- *
- * \sa PRINTF_DISABLED
- * \sa PRINTF_NOMODIFIERS
- * \sa PRINTF_REDUCED
- * \sa PRINTF_NOFLOAT
- * \sa PRINTF_FULL
- */
-#define CONFIG_PRINTF PRINTF_FULL
-
-/**
- * Multithreading kernel.
- *
- * \sa config_kern.h
- */
-#define CONFIG_KERNEL 0
-
-/**
- * \name Serial driver parameters
- * \{
- */
-       /** [bytes] Size of the outbound FIFO buffer for port 0. */
-       #define CONFIG_UART0_TXBUFSIZE  32
-
-       /** [bytes] Size of the inbound FIFO buffer for port 0. */
-       #define CONFIG_UART0_RXBUFSIZE  64
-
-       /** [bytes] Size of the outbound FIFO buffer for port 1. */
-       #define CONFIG_UART1_TXBUFSIZE  32
-
-       /** [bytes] Size of the inbound FIFO buffer for port 1. */
-       #define CONFIG_UART1_RXBUFSIZE  64
-
-       /** [bytes] Size of the outbound FIFO buffer for SPI port (AVR only). */
-       #define CONFIG_SPI_TXBUFSIZE    16
-
-       /** [bytes] Size of the inbound FIFO buffer for SPI port (AVR only). */
-       #define CONFIG_SPI_RXBUFSIZE    32
-
-       /** SPI data order (AVR only). */
-       #define CONFIG_SPI_DATA_ORDER   SER_MSB_FIRST
-
-       /** SPI clock division factor (AVR only). */
-       #define CONFIG_SPI_CLOCK_DIV    16
-
-       /** SPI clock polarity: 0 = normal low, 1 = normal high (AVR only). */
-       #define CONFIG_SPI_CLOCK_POL    0
-
-       /** SPI clock phase: 0 = sample on first edge, 1 = sample on second clock edge (AVR only). */
-       #define CONFIG_SPI_CLOCK_PHASE  0
-
-       /** Default transmit timeout (ms). Set to -1 to disable timeout support */
-       #define CONFIG_SER_TXTIMEOUT    -1
-
-       /** Default receive timeout (ms). Set to -1 to disable timeout support */
-       #define CONFIG_SER_RXTIMEOUT    -1
-
-       /** Use RTS/CTS handshake */
-       #define CONFIG_SER_HWHANDSHAKE   0
-
-       /** Default baud rate (set to 0 to disable) */
-       #define CONFIG_SER_DEFBAUDRATE   0
-
-       /** Enable ser_gets() and ser_gets_echo() */
-       #define CONFIG_SER_GETS          0
-
-       /** Enable second serial port in emulator. */
-       #define CONFIG_EMUL_UART1        0
-
-       /**
-        * Transmit always something on serial port 0 TX
-        * to avoid interference when sending burst of data,
-        * using AVR multiprocessor serial mode
-        */
-       #define CONFIG_SER_TXFILL        0
-
-       #define CONFIG_SER_STROBE        0
-/*\}*/
-
-/// Hardware timer selection for drv/timer.c
-#define CONFIG_TIMER  TIMER_ON_OUTPUT_COMPARE2
-
-/// Debug timer interrupt using a strobe pin.
-#define CONFIG_TIMER_STROBE  0
-
-/// Enable ADS strobe.
-#define CONFIG_ADC_STROBE  0
-
-/// Enable watchdog timer.
-#define CONFIG_WATCHDOG  0
-
-/// EEPROM type for drv/eeprom.c
-#define CONFIG_EEPROM_TYPE EEPROM_24XX256
-
-/// Select bitmap pixel format.
-#define CONFIG_BITMAP_FMT  BITMAP_FMT_PLANAR_V_LSB
-
-/// Enable line clipping algorithm.
-#define CONFIG_GFX_CLIPPING  1
-
-/// Enable text rendering in bitmaps.
-#define CONFIG_GFX_TEXT  1
-
-/// Enable virtual coordinate system.
-#define CONFIG_GFX_VCOORDS  1
-
-/// Keyboard polling method
-#define CONFIG_KBD_POLL  KBD_POLL_SOFTINT
-
-/// Enable keyboard event delivery to observers
-#define CONFIG_KBD_OBSERVER  0
-
-/// Enable key beeps
-#define CONFIG_KBD_BEEP  1
-
-/// Enable long pression handler for keys
-#define CONFIG_KBD_LONGPRESS  1
-
-/**
- * \name Type for the chart dataset
- * \{
- */
-#define CONFIG_CHART_TYPE_X uint8_t
-#define CONFIG_CHART_TYPE_Y uint8_t
-/*\}*/
-
-/// Enable button bar behind menus
-#define CONFIG_MENU_MENUBAR  0
-
-/// Enable smooth scrolling in menus
-#define CONFIG_MENU_SMOOTH  1
-
-/// Size of block for MD2 algorithm.
-#define CONFIG_MD2_BLOCK_LEN 16
-
-/// Use standard permutation in MD2 algorithm.
-#define CONFIG_MD2_STD_PERM 0
-
-/// Define a size, in byte, of entropy pool.
-#define CONFIG_SIZE_ENTROPY_POOL 64
-
-/// Turn on or off timer support in Randpool.
-#define CONFIG_RANDPOOL_TIMER 1
-
-#endif /* APPCONFIG_H */
diff --git a/app/demo/battfs_test.c b/app/demo/battfs_test.c
deleted file mode 100644 (file)
index a0b8e34..0000000
+++ /dev/null
@@ -1,131 +0,0 @@
-/**
- * \file
- * <!--
- * This file is part of BeRTOS.
- *
- * Bertos is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
- *
- * As a special exception, you may use this file as part of a free software
- * library without restriction.  Specifically, if other files instantiate
- * templates or use macros or inline functions from this file, or you compile
- * this file and link it with other files to produce an executable, this
- * file does not by itself cause the resulting executable to be covered by
- * the GNU General Public License.  This exception does not however
- * invalidate any other reasons why the executable file might be covered by
- * the GNU General Public License.
- *
- * Copyright 2007 Develer S.r.l. (http://www.develer.com/)
- *
- * -->
- *
- * \version $Id: demo.c 18242 2007-10-08 17:35:23Z marco $
- *
- * \author Francesco Sacchi <batt@develer.com>
- *
- * \brief BattFs Test.
- */
-
-#include <cfg/debug.h>
-#include <fs/battfs.h>
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <string.h>
-
-FILE *fp;
-const char test_filename[]="battfs_disk.bin";
-const char *filename;
-
-#define PAGE_SIZE 128
-static bool disk_open(struct BattFsSuper *d)
-{
-       fp = fopen(filename, "r+b");
-       ASSERT(fp);
-       fseek(fp, 0, SEEK_END);
-       d->page_size = PAGE_SIZE;
-       d->page_count = ftell(fp) / d->page_size;
-       d->disk_size = d->page_size * d->page_count;
-       d->page_array = malloc(d->page_count * sizeof(pgcnt_t));
-       TRACEMSG("page_size:%d, page_count:%d, disk_size:%d\n", d->page_size, d->page_count, d->disk_size);
-       return (fp && d->page_array);
-}
-
-static size_t disk_page_read(struct BattFsSuper *d, pgcnt_t page, pgaddr_t addr, void *buf, size_t size)
-{
-       TRACEMSG("page:%d, addr:%d, size:%d\n", page, addr, size);
-       fseek(fp, page * d->page_size + addr, SEEK_SET);
-       return fread(buf, 1, size, fp);
-}
-
-static size_t disk_page_write(struct BattFsSuper *d, pgcnt_t page, pgaddr_t addr, void *buf, size_t size)
-{
-       TRACEMSG("page:%d, addr:%d, size:%d\n", page, addr, size);
-       fseek(fp, page * d->page_size + addr, SEEK_SET);
-       return fwrite(buf, 1, size, fp);
-}
-
-static bool disk_page_erase(struct BattFsSuper *d, pgcnt_t page)
-{
-       TRACEMSG("page:%d\n", page);
-       fseek(fp, page * d->page_size, SEEK_SET);
-
-       for (int i = 0; i < d->page_size; i++)
-               if (fputc(0xff, fp) == EOF)
-                       return false;
-       return true;
-}
-
-static bool disk_close(struct BattFsSuper *d)
-{
-       TRACE;
-       free(d->page_array);
-       return (fclose(fp) != EOF);
-}
-
-int main(int argc, char *argv[])
-{
-       if (argc < 2)
-       {
-               FILE *fpt = fopen(test_filename, "w+");
-               for (int i = 0; i < 32768; i++)
-                       fputc(0xff, fpt);
-               fclose(fpt);
-               filename = test_filename;
-       }
-       else
-               filename = argv[1];
-
-       BattFsSuper disk;
-       disk.open = disk_open;
-       disk.read = disk_page_read;
-       disk.write = disk_page_write;
-       disk.erase = disk_page_erase;
-       disk.close = disk_close;
-
-       if (battfs_init(&disk))
-       {
-               kprintf("page_array:\n");
-               for (pgcnt_t i = 0; i < disk.page_count; i++)
-               {
-                       if (!(i % 16))
-                               kputchar('\n');
-                       kprintf("%04d ", disk.page_array[i]);
-               }
-               kputchar('\n');
-               return 0;
-       }
-       else
-               return 1;
-}
diff --git a/app/demo/battfs_test.mk b/app/demo/battfs_test.mk
deleted file mode 100644 (file)
index 5df84bf..0000000
+++ /dev/null
@@ -1,29 +0,0 @@
-#
-# $Id: demo.mk 18234 2007-10-08 13:39:48Z rasky $
-# Copyright 2003, 2004, 2005, 2006 Develer S.r.l. (http://www.develer.com/)
-# All rights reserved.
-#
-# Makefile fragment for DevLib demo application.
-#
-# Author: Bernardo Innocenti <bernie@develer.com>
-#
-
-# Set to 1 for debug builds
-battfs_test_DEBUG = 1
-
-# Our target application
-TRG += battfs_test
-
-
-battfs_test_CSRC = \
-       fs/battfs.c \
-       app/battfs/battfs_test.c
-
-battfs_test_CFLAGS = -O0 -D'ARCH=ARCH_EMUL' -D_EMUL -Iapp/battfs -Ihw -g3
-
-
-# Debug stuff
-ifeq ($(battfs_test_DEBUG),1)
-       battfs_test_CFLAGS += -D_DEBUG
-endif
-
diff --git a/app/demo/verstag.h b/app/demo/verstag.h
deleted file mode 100644 (file)
index d84efd2..0000000
+++ /dev/null
@@ -1,94 +0,0 @@
-/**
- * \file
- * <!--
- * This file is part of BeRTOS.
- *
- * Bertos is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
- *
- * As a special exception, you may use this file as part of a free software
- * library without restriction.  Specifically, if other files instantiate
- * templates or use macros or inline functions from this file, or you compile
- * this file and link it with other files to produce an executable, this
- * file does not by itself cause the resulting executable to be covered by
- * the GNU General Public License.  This exception does not however
- * invalidate any other reasons why the executable file might be covered by
- * the GNU General Public License.
- *
- * Copyright 2003, 2004, 2005, 2006 Develer S.r.l. (http://www.develer.com/)
- * Copyright 2001, 2002, 2003 by Bernardo Innocenti <bernie@codewiz.org>
- *
- * -->
- *
- * \version $Id$
- *
- * \author Bernardo Innocenti <bernie@develer.com>
- *
- * \brief Declare application version strings
- */
-#ifndef DEVLIB_VERSTAG_H
-#define DEVLIB_VERSTAG_H
-
-#ifndef ARCH_CONFIG_H
-       #include "cfg/arch_config.h"
-#endif
-
-#define APP_NAME "Devlib Demo"
-#define APP_DESCRIPTION "DevLib Multidemo Application"
-#define APP_AUTHOR "Develer"
-#define APP_COPYRIGHT "Copyright 2006 Develer (http://www.develer.com/)"
-
-#define VERS_MAJOR 0
-#define VERS_MINOR 1
-#define VERS_REV   0
-#define VERS_LETTER ""
-
-/**
- * If _SNAPSHOT is defined, \c VERS_TAG contains the build date
- * date instead of a numeric version string.
- */
-#define _SNAPSHOT
-
-#ifdef _DEBUG
-       #define VERS_DBG "D"
-#else
-       #define VERS_DBG ""
-#endif
-
-#define __STRINGIZE(x) #x
-#define _STRINGIZE(x) __STRINGIZE(x)
-
-/** Build application version string (i.e.: "1.7.0") */
-#define MAKE_VERS(maj,min,rev) _STRINGIZE(maj) "." _STRINGIZE(min) "." _STRINGIZE(rev) VERS_LETTER VERS_DBG
-#ifdef _SNAPSHOT
-       #define VERS_TAG "snapshot" " " __DATE__ " " __TIME__ " " VERS_LETTER " " VERS_DBG
-#else
-       #define VERS_TAG MAKE_VERS(VERS_MAJOR,VERS_MINOR,VERS_REV)
-#endif
-
-/** Build application version string suitable for MS windows resource files (i.e.: "1, 7, 0, 1") */
-#define MAKE_RCVERS(maj,min,rev,bld) _STRINGIZE(maj) ", " _STRINGIZE(min) ", " _STRINGIZE(rev) ", " _STRINGIZE(bld)
-#define RCVERSION_TAG MAKE_VERS(VERS_MAJOR,VERS_MINOR,VERS_REV)
-
-/** The revision string (contains VERS_TAG) */
-extern const char vers_tag[];
-
-/** Sequential build number (contains VERS_BUILD) */
-extern const int vers_build_nr;
-//extern const char vers_build_str[];
-
-/** Hostname of the machine used to build this binary (contains VERS_HOST) */
-extern const char vers_host[];
-
-#endif /* DEVLIB_VERSTAG_H */