X-Git-Url: http://www.aleph1.co.uk/gitweb/?p=yaffs2.git;a=blobdiff_plain;f=direct%2Fydirectenv.h;h=536ff22068c4a2d1be86b151133023fc55f8d94f;hp=c651394c80b0901de4aa2d115f8e3ba60f5d2159;hb=fb1a7ee223619260cfd9b6366fd78747cc572cd5;hpb=378bbdf4d64b8b26db55a495ab6ae520ff62e471 diff --git a/direct/ydirectenv.h b/direct/ydirectenv.h index c651394..536ff22 100644 --- a/direct/ydirectenv.h +++ b/direct/ydirectenv.h @@ -1,8 +1,7 @@ /* - * YAFFS: Yet another FFS. A NAND-flash specific file system. - * ydirectenv.h: Environment wrappers for direct. + * YAFFS: Yet another Flash File System . A NAND-flash specific file system. * - * Copyright (C) 2002 Aleph One Ltd. + * Copyright (C) 2002-2010 Aleph One Ltd. * for Toby Churchill Ltd and Brightstar Engineering * * Created by Charles Manning @@ -11,47 +10,55 @@ * it under the terms of the GNU Lesser General Public License version 2.1 as * published by the Free Software Foundation. * - * * Note: Only YAFFS headers are LGPL, YAFFS C code is covered by GPL. - * - * $Id: ydirectenv.h,v 1.4 2006-10-03 10:13:03 charles Exp $ - * */ - + +/* + * ydirectenv.h: Environment wrappers for YAFFS direct. + */ + #ifndef __YDIRECTENV_H__ #define __YDIRECTENV_H__ // Direct interface -#include "devextras.h" - #include "stdlib.h" #include "stdio.h" #include "string.h" +#include "yaffs_osglue.h" +#include "yaffs_hweight.h" + +#include "assert.h" +#define YBUG() assert(0) +//#define YBUG() do { *((int *)0) =1;} while(0) + #define YCHAR char #define YUCHAR unsigned char #define _Y(x) x -#define yaffs_strcpy(a,b) strcpy(a,b) -#define yaffs_strncpy(a,b,c) strncpy(a,b,c) -#define yaffs_strlen(s) strlen(s) -#define yaffs_sprintf sprintf -#define yaffs_toupper(a) toupper(a) + +#define hweight8(x) yaffs_hweight8(x) +#define hweight32(x) yaffs_hweight32(x) + +void yaffs_qsort(void *aa, size_t n, size_t es, + int (*cmp)(const void *, const void *)); + +#define sort(base, n, sz, cmp_fn, swp) yaffs_qsort(base, n, sz, cmp_fn) + +#define YAFFS_PATH_DIVIDERS "/" #ifdef NO_Y_INLINE #define Y_INLINE #else -#define Y_INLINE inline +#define Y_INLINE __inline__ #endif -#define YMALLOC(x) malloc(x) -#define YFREE(x) free(x) -#define YMALLOC_ALT(x) malloc(x) -#define YFREE_ALT(x) free(x) - -#define YMALLOC_DMA(x) malloc(x) +#define kmalloc(x,flags) yaffs_malloc(x) +#define kfree(x) yaffs_free(x) +#define vmalloc(x) yaffs_malloc(x) +#define vfree(x) yaffs_free(x) -#define YYIELD() do {} while(0) +#define cond_resched() do {} while(0) @@ -61,6 +68,7 @@ #define TENDSTR "\n" #define TSTR(x) x +#define TCONT(x) x #define TOUT(p) printf p @@ -76,8 +84,9 @@ #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) +#include "yaffs_list.h" + +#include "yaffsfs.h" #endif