*** empty log message ***
[yaffs/.git] / yportenv.h
index 63931749fc1d10964209153b7f370061048b84f7..f95c6eebd06f5cd5d75a85603b9e12d3715a99ec 100644 (file)
  *
  * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL.
  *
- * $Id: yportenv.h,v 1.5 2002-09-27 20:50:50 charles Exp $
+ * $Id: yportenv.h,v 1.10 2003-01-31 03:30:33 charles Exp $
  *
  */
  
-#ifndef __PORTENV_H__
-#define __PORTENV_H__
+#ifndef __YPORTENV_H__
+#define __YPORTENV_H__
 
 
-#if defined WIN32
+#if defined CONFIG_YAFFS_WINCE
 
-// Win32
+// CONFIG_YAFFS_WINCE
 #include "stdlib.h"
 #include "stdio.h"
 #include "string.h"
 
+#define CONFIG_YAFFS_CASE_INSENSITIVE
+
 #define YMALLOC(x) malloc(x)
 #define YFREE(x)   free(x)
 
 
 #include <windows.h>
 
-#define YAFFS_LOSTNFOUND_NAME          "LOST_CLUSTERS"
+#define YAFFS_LOSTNFOUND_NAME          "Lost Clusters"
 #define YAFFS_LOSTNFOUND_PREFIX                "OBJ"
 
-#define YPRINTF(x)
+#define YPRINTF(x)     RETAILMSG(1,x)
 
 // Always pass the sum compare to overcome the case insensitivity issue
-#define yaffs_SumCompare(x,y) 1
+#define yaffs_SumCompare(x,y) ((x) == (y))
 #define yaffs_strcmp(a,b) _stricmp(a,b)
 
 
@@ -62,12 +64,12 @@ extern unsigned yfsd_U32FileTimeNow(void);
 
 #define CURRENT_TIME                            yfsd_U32FileTimeNow()
 #define YAFFS_ROOT_MODE                                FILE_ATTRIBUTE_ARCHIVE
-#define YAFFS_LOSTNFOUND_MODE          (FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_HIDDEN)
+#define YAFFS_LOSTNFOUND_MODE          FILE_ATTRIBUTE_HIDDEN
 
 
-#define TENDSTR "\r\n"
+#define TENDSTR L"\r\n"
 #define TSTR(x) TEXT(x)
-#define T(x) RETAILMSG(1, x)
+#define TOUT(x) RETAILMSG(1, x)
 
 
 #elif  defined __KERNEL__
@@ -79,10 +81,12 @@ extern unsigned yfsd_U32FileTimeNow(void);
 #include "linux/mm.h"
 #include "linux/string.h"
 #include "linux/slab.h"
+
+
 #define YAFFS_LOSTNFOUND_NAME          "lost+found"
 #define YAFFS_LOSTNFOUND_PREFIX                "obj"
 
-#define YPRINTF(x) printk x
+//#define YPRINTF(x) printk x
 #define YMALLOC(x) kmalloc(x,GFP_KERNEL)
 #define YFREE(x)   kfree(x)
 
@@ -95,12 +99,13 @@ extern unsigned yfsd_U32FileTimeNow(void);
 
 #define TENDSTR "\n"
 #define TSTR(x) KERN_DEBUG x
-#define T(x) printk x
+#define TOUT(p) printk p
 
 
-#else
+#elif defined CONFIG_YAFFS_DIRECT
+
+// Direct interface
 
-// Linux application
 #include "stdlib.h"
 #include "stdio.h"
 #include "string.h"
@@ -109,18 +114,53 @@ extern unsigned yfsd_U32FileTimeNow(void);
 #define YFREE(x)   free(x)
 
 
-#define YINFO(s) YPRINTF(( __FILE__ " %d %s\n",__LINE__,s))
-#define YALERT(s) YINFO(s)
+//#define YINFO(s) YPRINTF(( __FILE__ " %d %s\n",__LINE__,s))
+//#define YALERT(s) YINFO(s)
 
 
 #define TENDSTR "\n"
 #define TSTR(x) x
-#define T(x) printf x
+#define TOUT(p) printf p
 
 
 #define YAFFS_LOSTNFOUND_NAME          "lost+found"
 #define YAFFS_LOSTNFOUND_PREFIX                "obj"
-#define YPRINTF(x) printf x
+//#define YPRINTF(x) printf x
+
+#include "yaffscfg.h"
+
+#define CURRENT_TIME yaffsfs_CurrentTime()
+#define YAFFS_ROOT_MODE                                0666
+#define YAFFS_LOSTNFOUND_MODE          0666
+
+#define yaffs_SumCompare(x,y) ((x) == (y))
+#define yaffs_strcmp(a,b) strcmp(a,b)
+
+#elif defined CONFIG_YAFFS_UTIL
+
+// Stuff for YAFFS utilities
+
+#include "stdlib.h"
+#include "stdio.h"
+#include "string.h"
+
+#define YMALLOC(x) malloc(x)
+#define YFREE(x)   free(x)
+
+
+//#define YINFO(s) YPRINTF(( __FILE__ " %d %s\n",__LINE__,s))
+//#define YALERT(s) YINFO(s)
+
+
+#define TENDSTR "\n"
+#define TSTR(x) x
+#define TOUT(p) printf p
+
+
+#define YAFFS_LOSTNFOUND_NAME          "lost+found"
+#define YAFFS_LOSTNFOUND_PREFIX                "obj"
+//#define YPRINTF(x) printf x
+
 
 #define CURRENT_TIME 0
 #define YAFFS_ROOT_MODE                                0666
@@ -129,17 +169,36 @@ extern unsigned yfsd_U32FileTimeNow(void);
 #define yaffs_SumCompare(x,y) ((x) == (y))
 #define yaffs_strcmp(a,b) strcmp(a,b)
 
-#endif 
+#else
+// Should have specified a configuration type
+#error Unknown configuration
 
+#endif 
 
 
-#undef YINFO
+extern unsigned yaffs_traceMask;
 
+#define YAFFS_TRACE_ERROR              0x0001
+#define YAFFS_TRACE_OS                 0x0002
+#define YAFFS_TRACE_ALLOCATE   0x0004
+#define YAFFS_TRACE_SCAN               0x0008
+#define YAFFS_TRACE_BAD_BLOCKS 0x0010
+#define YAFFS_TRACE_ERASE              0x0020
+#define YAFFS_TRACE_GC                 0x0040
+#define YAFFS_TRACE_TRACING            0x0100
+#define YAFFS_TRACE_ALWAYS             0x0200
+#define YAFFS_TRACE_BUG                        0x8000
 
-#define YINFO(s) YPRINTF((KERN_DEBUG __FILE__ " %d %s\n",__LINE__,s))
-#define YALERT(s) YINFO(s)
+#define T(mask,p) do{ if((mask) & (yaffs_traceMask | YAFFS_TRACE_ERROR)) TOUT(p);} while(0) 
 
-#define YBUG() do{YINFO("bug");} while(0)
+//#undef YINFO
 
 
+//#define YINFO(s) YPRINTF((KERN_DEBUG __FILE__ " %d %s\n",__LINE__,s))
+//#define YALERT(s) YINFO(s)
+#ifdef CONFIG_YAFFS_WINCE
+#define YBUG() T(YAFFS_TRACE_BUG,(TSTR("==>> yaffs bug: %s %d" TENDSTR),TEXT(__FILE__),__LINE__))
+#else
+#define YBUG() T(YAFFS_TRACE_BUG,(TSTR("==>> yaffs bug: " __FILE__ " %d" TENDSTR),__LINE__))
+#endif
 #endif