forked from len0rd/rockbox
android/ypr0: Merge fs-*.c to generic filesystem-unix.c.
Change-Id: I52e2c29346baf0d282243880477cd149311ce3d1
This commit is contained in:
parent
954cd771fb
commit
5d13ecc4a8
6 changed files with 9 additions and 168 deletions
|
@ -78,10 +78,10 @@ drivers/rtc/rtc_as3514.c
|
||||||
target/hosted/rtc.c
|
target/hosted/rtc.c
|
||||||
#endif
|
#endif
|
||||||
target/hosted/kernel-unix.c
|
target/hosted/kernel-unix.c
|
||||||
|
target/hosted/filesystem-unix.c
|
||||||
target/hosted/ypr0/button-ypr0.c
|
target/hosted/ypr0/button-ypr0.c
|
||||||
target/hosted/ypr0/lcd-ypr0.c
|
target/hosted/ypr0/lcd-ypr0.c
|
||||||
target/hosted/ypr0/system-ypr0.c
|
target/hosted/ypr0/system-ypr0.c
|
||||||
target/hosted/ypr0/fs-ypr0.c
|
|
||||||
target/hosted/ypr0/lc-ypr0.c
|
target/hosted/ypr0/lc-ypr0.c
|
||||||
thread.c
|
thread.c
|
||||||
#ifdef HAVE_BACKLIGHT
|
#ifdef HAVE_BACKLIGHT
|
||||||
|
@ -1693,7 +1693,7 @@ target/arm/rk27xx/hm801/power-hm801.c
|
||||||
|
|
||||||
#if (CONFIG_PLATFORM & PLATFORM_ANDROID)
|
#if (CONFIG_PLATFORM & PLATFORM_ANDROID)
|
||||||
target/hosted/kernel-unix.c
|
target/hosted/kernel-unix.c
|
||||||
target/hosted/android/fs-android.c
|
target/hosted/filesystem-unix.c
|
||||||
target/hosted/android/lcd-android.c
|
target/hosted/android/lcd-android.c
|
||||||
target/hosted/android/lc-android.c
|
target/hosted/android/lc-android.c
|
||||||
target/hosted/android/button-android.c
|
target/hosted/android/button-android.c
|
||||||
|
|
|
@ -40,17 +40,13 @@
|
||||||
#undef rmdir
|
#undef rmdir
|
||||||
|
|
||||||
|
|
||||||
|
#if (CONFIG_PLATFORM & PLATFORM_ANDROID) || defined(SAMSUNG_YPR0)
|
||||||
|
#include "dir-target.h"
|
||||||
|
#define opendir _opendir
|
||||||
|
#define mkdir _mkdir
|
||||||
#if (CONFIG_PLATFORM & PLATFORM_ANDROID)
|
#if (CONFIG_PLATFORM & PLATFORM_ANDROID)
|
||||||
#include "dir-target.h"
|
|
||||||
#define opendir opendir_android
|
|
||||||
#define mkdir mkdir_android
|
|
||||||
#define rmdir rmdir_android
|
|
||||||
static const char rbhome[] = "/sdcard";
|
static const char rbhome[] = "/sdcard";
|
||||||
#elif defined(SAMSUNG_YPR0)
|
#endif
|
||||||
#include "dir-target.h"
|
|
||||||
#define opendir opendir_ypr0
|
|
||||||
#define mkdir mkdir_ypr0
|
|
||||||
#define rmdir rmdir_ypr0
|
|
||||||
#elif (CONFIG_PLATFORM & (PLATFORM_SDL|PLATFORM_MAEMO|PLATFORM_PANDORA))
|
#elif (CONFIG_PLATFORM & (PLATFORM_SDL|PLATFORM_MAEMO|PLATFORM_PANDORA))
|
||||||
#define open sim_open
|
#define open sim_open
|
||||||
#define remove sim_remove
|
#define remove sim_remove
|
||||||
|
|
|
@ -32,16 +32,9 @@
|
||||||
#define mkdir_uncached _mkdir
|
#define mkdir_uncached _mkdir
|
||||||
#define rmdir_uncached rmdir
|
#define rmdir_uncached rmdir
|
||||||
|
|
||||||
#define dirent_android dirent
|
|
||||||
#define DIR_android DIR
|
|
||||||
#define opendir_android _opendir
|
|
||||||
#define readdir_android _readdir
|
|
||||||
#define closedir_android _closedir
|
|
||||||
#define mkdir_android _mkdir
|
|
||||||
#define rmdir_android rmdir
|
|
||||||
|
|
||||||
extern DIR* _opendir(const char* name);
|
extern DIR* _opendir(const char* name);
|
||||||
extern int _mkdir(const char* name);
|
extern int _mkdir(const char* name);
|
||||||
|
extern int rmdir(const char* name);
|
||||||
extern int _closedir(DIR* dir);
|
extern int _closedir(DIR* dir);
|
||||||
extern struct dirent *_readdir(DIR* dir);
|
extern struct dirent *_readdir(DIR* dir);
|
||||||
extern void fat_size(unsigned long *size, unsigned long *free);
|
extern void fat_size(unsigned long *size, unsigned long *free);
|
||||||
|
|
|
@ -1,141 +0,0 @@
|
||||||
/***************************************************************************
|
|
||||||
* __________ __ ___.
|
|
||||||
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
|
|
||||||
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
|
|
||||||
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
|
|
||||||
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
|
|
||||||
* \/ \/ \/ \/ \/
|
|
||||||
* $Id$
|
|
||||||
*
|
|
||||||
* Copyright (C) 2010 by Thomas Martitz
|
|
||||||
*
|
|
||||||
* This program 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 software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
||||||
* KIND, either express or implied.
|
|
||||||
*
|
|
||||||
****************************************************************************/
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <sys/stat.h> /* stat() */
|
|
||||||
#include <stdio.h> /* snprintf */
|
|
||||||
#include <string.h> /* size_t */
|
|
||||||
#include <dirent.h>
|
|
||||||
#include <time.h> /* localtime() */
|
|
||||||
#include "system-target.h"
|
|
||||||
#include "dir-target.h"
|
|
||||||
#include "file.h"
|
|
||||||
#include "dir.h"
|
|
||||||
#include "rbpaths.h"
|
|
||||||
|
|
||||||
|
|
||||||
long filesize(int fd)
|
|
||||||
{
|
|
||||||
struct stat buf;
|
|
||||||
|
|
||||||
if (!fstat(fd, &buf))
|
|
||||||
return buf.st_size;
|
|
||||||
else
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* do we really need this in the app? */
|
|
||||||
void fat_size(unsigned long* size, unsigned long* free)
|
|
||||||
{
|
|
||||||
*size = *free = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#undef opendir
|
|
||||||
#undef closedir
|
|
||||||
#undef mkdir
|
|
||||||
#undef readdir
|
|
||||||
|
|
||||||
/* need to wrap around DIR* because we need to save the parent's
|
|
||||||
* directory path in order to determine dirinfo */
|
|
||||||
struct __dir {
|
|
||||||
DIR *dir;
|
|
||||||
char *path;
|
|
||||||
};
|
|
||||||
|
|
||||||
DIR* _opendir(const char *name)
|
|
||||||
{
|
|
||||||
char *buf = malloc(sizeof(struct __dir) + strlen(name)+1);
|
|
||||||
if (!buf)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
struct __dir *this = (struct __dir*)buf;
|
|
||||||
|
|
||||||
this->path = buf+sizeof(struct __dir);
|
|
||||||
/* definitely fits due to strlen() */
|
|
||||||
strcpy(this->path, name);
|
|
||||||
|
|
||||||
this->dir = opendir(name);
|
|
||||||
|
|
||||||
if (!this->dir)
|
|
||||||
{
|
|
||||||
free(buf);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
return (DIR*)this;
|
|
||||||
}
|
|
||||||
|
|
||||||
int _mkdir(const char *name)
|
|
||||||
{
|
|
||||||
return mkdir(name, 0777);
|
|
||||||
}
|
|
||||||
|
|
||||||
int _closedir(DIR *dir)
|
|
||||||
{
|
|
||||||
struct __dir *this = (struct __dir*)dir;
|
|
||||||
int ret = closedir(this->dir);
|
|
||||||
free(this);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
struct dirent* _readdir(DIR* dir)
|
|
||||||
{
|
|
||||||
struct __dir *d = (struct __dir*)dir;
|
|
||||||
return readdir(d->dir);
|
|
||||||
}
|
|
||||||
|
|
||||||
struct dirinfo dir_get_info(struct DIR* _parent, struct dirent *dir)
|
|
||||||
{
|
|
||||||
struct __dir *parent = (struct __dir*)_parent;
|
|
||||||
struct stat s;
|
|
||||||
struct tm *tm = NULL;
|
|
||||||
struct dirinfo ret;
|
|
||||||
char path[MAX_PATH];
|
|
||||||
|
|
||||||
snprintf(path, sizeof(path), "%s/%s", parent->path, dir->d_name);
|
|
||||||
memset(&ret, 0, sizeof(ret));
|
|
||||||
|
|
||||||
if (!stat(path, &s))
|
|
||||||
{
|
|
||||||
if (S_ISDIR(s.st_mode))
|
|
||||||
{
|
|
||||||
ret.attribute = ATTR_DIRECTORY;
|
|
||||||
}
|
|
||||||
ret.size = s.st_size;
|
|
||||||
tm = localtime(&(s.st_mtime));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!lstat(path, &s) && S_ISLNK(s.st_mode))
|
|
||||||
{
|
|
||||||
ret.attribute |= ATTR_LINK;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (tm)
|
|
||||||
{
|
|
||||||
ret.wrtdate = ((tm->tm_year - 80) << 9) |
|
|
||||||
((tm->tm_mon + 1) << 5) |
|
|
||||||
tm->tm_mday;
|
|
||||||
ret.wrttime = (tm->tm_hour << 11) |
|
|
||||||
(tm->tm_min << 5) |
|
|
||||||
(tm->tm_sec >> 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
|
@ -35,16 +35,9 @@ extern int rmdir(const char* name);
|
||||||
#define mkdir_uncached _mkdir
|
#define mkdir_uncached _mkdir
|
||||||
#define rmdir_uncached rmdir
|
#define rmdir_uncached rmdir
|
||||||
|
|
||||||
#define dirent_ypr0 dirent
|
|
||||||
#define DIR_ypr0 DIR
|
|
||||||
#define opendir_ypr0 _opendir
|
|
||||||
#define readdir_ypr0 _readdir
|
|
||||||
#define closedir_ypr0 _closedir
|
|
||||||
#define mkdir_ypr0 _mkdir
|
|
||||||
#define rmdir_ypr0 rmdir
|
|
||||||
|
|
||||||
extern DIR* _opendir(const char* name);
|
extern DIR* _opendir(const char* name);
|
||||||
extern int _mkdir(const char* name);
|
extern int _mkdir(const char* name);
|
||||||
|
extern int _rmdir(const char* name);
|
||||||
extern int _closedir(DIR* dir);
|
extern int _closedir(DIR* dir);
|
||||||
extern struct dirent *_readdir(DIR* dir);
|
extern struct dirent *_readdir(DIR* dir);
|
||||||
extern void fat_size(unsigned long *size, unsigned long *free);
|
extern void fat_size(unsigned long *size, unsigned long *free);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue