summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2009-06-24 23:33:33 +0000
committerpatacongo <patacongo@42af7a65-404d-4744-a932-0658087f49c3>2009-06-24 23:33:33 +0000
commitf183944854afe2bd8ccb56ad20f79e3aa371dc02 (patch)
tree2a69a47a937599ba80e25151d9ae846f0492fd3a
parent57af094e9fea3a8e2ad7822b1c5336d0b63e4bca (diff)
downloadnuttx-f183944854afe2bd8ccb56ad20f79e3aa371dc02.tar.gz
nuttx-f183944854afe2bd8ccb56ad20f79e3aa371dc02.tar.bz2
nuttx-f183944854afe2bd8ccb56ad20f79e3aa371dc02.zip
Fix a bug in initial XIP offset
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@1942 42af7a65-404d-4744-a932-0658087f49c3
-rw-r--r--nuttx/ChangeLog3
-rw-r--r--nuttx/Documentation/NuttX.html3
-rw-r--r--nuttx/drivers/ramdisk.c30
-rw-r--r--nuttx/fs/romfs/fs_romfs.c89
-rw-r--r--nuttx/fs/romfs/fs_romfsutil.c11
5 files changed, 119 insertions, 17 deletions
diff --git a/nuttx/ChangeLog b/nuttx/ChangeLog
index fb7458acd..9d17fa4b7 100644
--- a/nuttx/ChangeLog
+++ b/nuttx/ChangeLog
@@ -795,6 +795,9 @@
include paths for Cygwin-based GCC were being converted to windows
native paths. That causes many problems -- breaking dependencies
for one.
+ * Fixed an important bug in ROMFS. The initial XIP offset was set
+ incorrectly so if sector zero was read first, there was a bad read.
+ I don't know how it worked before.
diff --git a/nuttx/Documentation/NuttX.html b/nuttx/Documentation/NuttX.html
index be4af316c..fdde2880e 100644
--- a/nuttx/Documentation/NuttX.html
+++ b/nuttx/Documentation/NuttX.html
@@ -1487,6 +1487,9 @@ nuttx-0.4.9 2009-xx-xx Gregory Nutt &lt;spudmonkey@racsa.co.cr&gt;
include paths for Cygwin-based GCC were being converted to windows
native paths. That causes many problems -- breaking dependencies
for one.
+ * Fixed an important bug in ROMFS. The initial XIP offset was set
+ incorrectly so if sector zero was read first, there was a bad read.
+ I don't know how it worked before.
pascal-0.1.3 2009-xx-xx Gregory Nutt &lt;spudmonkey@racsa.co.cr&gt;
diff --git a/nuttx/drivers/ramdisk.c b/nuttx/drivers/ramdisk.c
index 9273de114..1c44589ad 100644
--- a/nuttx/drivers/ramdisk.c
+++ b/nuttx/drivers/ramdisk.c
@@ -116,6 +116,7 @@ static const struct block_operations g_bops =
static int rd_open(FAR struct inode *inode)
{
+ fvdbg("Entry\n");
return OK;
}
@@ -128,6 +129,7 @@ static int rd_open(FAR struct inode *inode)
static int rd_close(FAR struct inode *inode)
{
+ fvdbg("Entry\n");
return OK;
}
@@ -143,12 +145,18 @@ static ssize_t rd_read(FAR struct inode *inode, unsigned char *buffer,
{
struct rd_struct_s *dev;
+ fvdbg("sector: %d nsectors: %d sectorsize: %d\n");
+
DEBUGASSERT(inode && inode->i_private);
dev = (struct rd_struct_s *)inode->i_private;
if (start_sector < dev->rd_nsectors &&
start_sector + nsectors <= dev->rd_nsectors)
{
- memcpy(buffer,
+ fvdbg("Transfer %d bytes from %p\n",
+ nsectors * dev->rd_sectsize,
+ &dev->rd_buffer[start_sector * dev->rd_sectsize]);
+
+ memcpy(buffer,
&dev->rd_buffer[start_sector * dev->rd_sectsize],
nsectors * dev->rd_sectsize);
return nsectors;
@@ -169,6 +177,8 @@ static ssize_t rd_write(FAR struct inode *inode, const unsigned char *buffer,
{
struct rd_struct_s *dev;
+ fvdbg("sector: %d nsectors: %d sectorsize: %d\n");
+
DEBUGASSERT(inode && inode->i_private);
dev = (struct rd_struct_s *)inode->i_private;
if (!dev->rd_writeenabled)
@@ -178,6 +188,10 @@ static ssize_t rd_write(FAR struct inode *inode, const unsigned char *buffer,
else if (start_sector < dev->rd_nsectors &&
start_sector + nsectors <= dev->rd_nsectors)
{
+ fvdbg("Transfer %d bytes from %p\n",
+ nsectors * dev->rd_sectsize,
+ &dev->rd_buffer[start_sector * dev->rd_sectsize]);
+
memcpy(&dev->rd_buffer[start_sector * dev->rd_sectsize],
buffer,
nsectors * dev->rd_sectsize);
@@ -198,6 +212,8 @@ static int rd_geometry(FAR struct inode *inode, struct geometry *geometry)
{
struct rd_struct_s *dev;
+ fvdbg("Entry\n");
+
DEBUGASSERT(inode);
if (geometry)
{
@@ -211,6 +227,12 @@ static int rd_geometry(FAR struct inode *inode, struct geometry *geometry)
#endif
geometry->geo_nsectors = dev->rd_nsectors;
geometry->geo_sectorsize = dev->rd_sectsize;
+
+ fvdbg("available: TRUE mediachanged: FALSE writeenabled: %s\n",
+ geometry->geo_writeenabled ? "TRUE" : "FALSE");
+ fvdbg("nsectors: %d sectorsize: %d\n",
+ geometry->geo_nsectors, geometry->geo_sectorsize);
+
return OK;
}
return -EINVAL;
@@ -228,6 +250,8 @@ static int rd_ioctl(FAR struct inode *inode, int cmd, unsigned long arg)
struct rd_struct_s *dev ;
void **ppv = (void**)arg;
+ fvdbg("Entry\n");
+
/* Only one ioctl command is supported */
DEBUGASSERT(inode && inode->i_private);
@@ -235,6 +259,8 @@ static int rd_ioctl(FAR struct inode *inode, int cmd, unsigned long arg)
{
dev = (struct rd_struct_s *)inode->i_private;
*ppv = (void*)dev->rd_buffer;
+
+ fvdbg("ppv: %p\n", *ppv);
return OK;
}
@@ -263,6 +289,8 @@ int romdisk_register(int minor, ubyte *buffer, uint32 nsectors, uint16 sectsize)
char devname[16];
int ret = -ENOMEM;
+ fvdbg("buffer: %p nsectors: %d sectsize: %d\n", buffer, nsectors, sectsize);
+
/* Sanity check */
#ifdef CONFIG_DEBUG
diff --git a/nuttx/fs/romfs/fs_romfs.c b/nuttx/fs/romfs/fs_romfs.c
index e031612f8..12ddc4bf9 100644
--- a/nuttx/fs/romfs/fs_romfs.c
+++ b/nuttx/fs/romfs/fs_romfs.c
@@ -1,7 +1,7 @@
/****************************************************************************
* rm/romfs/fs_romfs.h
*
- * Copyright (C) 2008 Gregory Nutt. All rights reserved.
+ * Copyright (C) 2008-2009 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
*
* References: Linux/Documentation/filesystems/romfs.txt
@@ -141,6 +141,8 @@ static int romfs_open(FAR struct file *filep, const char *relpath,
struct romfs_file_s *rf;
int ret;
+ fvdbg("Open '%s'\n", relpath);
+
/* Sanity checks */
DEBUGASSERT(filep->f_priv == NULL && filep->f_inode != NULL);
@@ -159,6 +161,7 @@ static int romfs_open(FAR struct file *filep, const char *relpath,
ret = romfs_checkmount(rm);
if (ret != OK)
{
+ fdbg("romfs_checkmount failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -168,6 +171,7 @@ static int romfs_open(FAR struct file *filep, const char *relpath,
if ((oflags & O_WRONLY) != 0 || (oflags & O_RDONLY) == 0)
{
+ fdbg("Only O_RDONLY supported\n");
ret = -EACCES;
goto errout_with_semaphore;
}
@@ -181,6 +185,8 @@ static int romfs_open(FAR struct file *filep, const char *relpath,
ret = romfs_finddirentry(rm, &dirinfo, relpath);
if (ret < 0)
{
+ fdbg("Failed to find directory directory entry for '%s': %d\n",
+ relpath, ret);
goto errout_with_semaphore;
}
@@ -193,6 +199,7 @@ static int romfs_open(FAR struct file *filep, const char *relpath,
/* It is a directory */
ret = -EISDIR;
+ fdbg("'%s' is a directory\n", relpath);
goto errout_with_semaphore;
}
@@ -200,13 +207,14 @@ static int romfs_open(FAR struct file *filep, const char *relpath,
# warning "Missing check for privileges based on inode->i_mode"
#endif
- /* Create an instance of the file private date to describe the opened
+ /* Create an instance of the file private data to describe the opened
* file.
*/
rf = (struct romfs_file_s *)zalloc(sizeof(struct romfs_file_s));
if (!rf)
{
+ fdbg("Failed to allocate private data\n", ret);
ret = -ENOMEM;
goto errout_with_semaphore;
}
@@ -224,6 +232,7 @@ static int romfs_open(FAR struct file *filep, const char *relpath,
&rf->rf_startoffset);
if (ret < 0)
{
+ fdbg("Failed to locate start of file data: %d\n", ret);
goto errout_with_semaphore;
}
@@ -232,6 +241,7 @@ static int romfs_open(FAR struct file *filep, const char *relpath,
ret = romfs_fileconfigure(rm, rf);
if (ret < 0)
{
+ fdbg("Failed configure buffering: %d\n", ret);
goto errout_with_semaphore;
}
@@ -268,14 +278,16 @@ static int romfs_close(FAR struct file *filep)
struct romfs_file_s *rf;
int ret = OK;
+ fvdbg("Closing\n");
+
/* Sanity checks */
DEBUGASSERT(filep->f_priv != NULL && filep->f_inode != NULL);
/* Recover our private data from the struct file instance */
- rf = filep->f_priv;
- rm = filep->f_inode->i_private;
+ rf = filep->f_priv;
+ rm = filep->f_inode->i_private;
DEBUGASSERT(rm != NULL);
@@ -320,14 +332,16 @@ static ssize_t romfs_read(FAR struct file *filep, char *buffer, size_t buflen)
int sectorndx;
int ret;
+ fvdbg("Read %d bytes from offset %d\n", buflen, filep->f_pos);
+
/* Sanity checks */
DEBUGASSERT(filep->f_priv != NULL && filep->f_inode != NULL);
/* Recover our private data from the struct file instance */
- rf = filep->f_priv;
- rm = filep->f_inode->i_private;
+ rf = filep->f_priv;
+ rm = filep->f_inode->i_private;
DEBUGASSERT(rm != NULL);
@@ -337,6 +351,7 @@ static ssize_t romfs_read(FAR struct file *filep, char *buffer, size_t buflen)
ret = romfs_checkmount(rm);
if (ret != OK)
{
+ fdbg("romfs_checkmount failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -381,9 +396,11 @@ static ssize_t romfs_read(FAR struct file *filep, char *buffer, size_t buflen)
/* Read all of the sectors directly into user memory */
+ fvdbg("Read %d sectors starting with %d\n", nsectors, sector);
ret = romfs_hwread(rm, userbuffer, sector, nsectors);
if (ret < 0)
{
+ fdbg("romfs_hwread failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -397,9 +414,11 @@ static ssize_t romfs_read(FAR struct file *filep, char *buffer, size_t buflen)
* it is already there then all is well.
*/
+ fvdbg("Read sector %d\n", sector);
ret = romfs_filecacheread(rm, rf, sector);
if (ret < 0)
{
+ fdbg("romfs_filecacheread failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -419,6 +438,7 @@ static ssize_t romfs_read(FAR struct file *filep, char *buffer, size_t buflen)
sector++;
}
+ fvdbg("Return %d bytes from sector offset %d\n", bytesread, sectorndx);
memcpy(userbuffer, &rf->rf_buffer[sectorndx], bytesread);
}
@@ -449,6 +469,8 @@ static off_t romfs_seek(FAR struct file *filep, off_t offset, int whence)
ssize_t position;
int ret;
+ fvdbg("Seek to offset: %d whence: %d\n", offset, whence);
+
/* Sanity checks */
DEBUGASSERT(filep->f_priv != NULL && filep->f_inode != NULL);
@@ -481,6 +503,7 @@ static off_t romfs_seek(FAR struct file *filep, off_t offset, int whence)
break;
default:
+ fdbg("Whence is invalid: %d\n", whence);
return -EINVAL;
}
@@ -490,7 +513,8 @@ static off_t romfs_seek(FAR struct file *filep, off_t offset, int whence)
ret = romfs_checkmount(rm);
if (ret != OK)
{
- goto errout_with_semaphore;
+ fdbg("romfs_checkmount failed: %d\n", ret);
+ goto errout_with_semaphore;
}
/* Limit positions to the end of the file. */
@@ -504,7 +528,8 @@ static off_t romfs_seek(FAR struct file *filep, off_t offset, int whence)
/* Set file position and return success */
- filep->f_pos = position;
+ filep->f_pos = position;
+ fvdbg("New file position: %d\n", filep->f_pos);
romfs_semgive(rm);
return OK;
@@ -524,14 +549,16 @@ static int romfs_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
struct romfs_file_s *rf;
FAR void **ppv = (FAR void**)arg;
+ fvdbg("cmd: %d arg: %08lx\n", cmd, arg);
+
/* Sanity checks */
DEBUGASSERT(filep->f_priv != NULL && filep->f_inode != NULL);
/* Recover our private data from the struct file instance */
- rf = filep->f_priv;
- rm = filep->f_inode->i_private;
+ rf = filep->f_priv;
+ rm = filep->f_inode->i_private;
DEBUGASSERT(rm != NULL);
@@ -547,6 +574,7 @@ static int romfs_ioctl(FAR struct file *filep, int cmd, unsigned long arg)
return OK;
}
+ fdbg("Invalid cmd: %d \n", cmd);
return -ENOTTY;
}
@@ -565,6 +593,8 @@ static int romfs_opendir(struct inode *mountpt, const char *relpath,
struct romfs_dirinfo_s dirinfo;
int ret;
+ fvdbg("relpath: '%s'\n", relpath);
+
/* Sanity checks */
DEBUGASSERT(mountpt != NULL && mountpt->i_private != NULL);
@@ -579,6 +609,7 @@ static int romfs_opendir(struct inode *mountpt, const char *relpath,
ret = romfs_checkmount(rm);
if (ret != OK)
{
+ fdbg("romfs_checkmount failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -587,6 +618,7 @@ static int romfs_opendir(struct inode *mountpt, const char *relpath,
ret = romfs_finddirentry(rm, &dirinfo, relpath);
if (ret < 0)
{
+ fdbg("Failed to find directory '%s': %d\n", relpath, ret);
goto errout_with_semaphore;
}
@@ -594,10 +626,11 @@ static int romfs_opendir(struct inode *mountpt, const char *relpath,
if (!IS_DIRECTORY(dirinfo.rd_next))
{
- /* The entry is not a directory */
+ /* The entry is not a directory */
- ret = -ENOTDIR;
- goto errout_with_semaphore;
+ fdbg("'%s' is not a directory: %d\n", relpath);
+ ret = -ENOTDIR;
+ goto errout_with_semaphore;
}
/* The entry is a directory */
@@ -627,6 +660,8 @@ static int romfs_readdir(struct inode *mountpt, struct internal_dir_s *dir)
uint32 size;
int ret;
+ fvdbg("Entry\n");
+
/* Sanity checks */
DEBUGASSERT(mountpt != NULL && mountpt->i_private != NULL);
@@ -641,6 +676,7 @@ static int romfs_readdir(struct inode *mountpt, struct internal_dir_s *dir)
ret = romfs_checkmount(rm);
if (ret != OK)
{
+ fdbg("romfs_checkmount failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -656,6 +692,7 @@ static int romfs_readdir(struct inode *mountpt, struct internal_dir_s *dir)
* special error -ENOENT
*/
+ fdbg("End of directory\n");
ret = -ENOENT;
goto errout_with_semaphore;
}
@@ -666,6 +703,7 @@ static int romfs_readdir(struct inode *mountpt, struct internal_dir_s *dir)
&next, &info, &size);
if (ret < 0)
{
+ fdbg("romfs_parsedirentry failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -674,6 +712,7 @@ static int romfs_readdir(struct inode *mountpt, struct internal_dir_s *dir)
ret = romfs_parsefilename(rm, dir->u.romfs.fr_curroffset, dir->fd_dir.d_name);
if (ret < 0)
{
+ fdbg("romfs_parsefilename failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -712,6 +751,8 @@ static int romfs_rewinddir(struct inode *mountpt, struct internal_dir_s *dir)
struct romfs_mountpt_s *rm;
int ret;
+ fvdbg("Entry\n");
+
/* Sanity checks */
DEBUGASSERT(mountpt != NULL && mountpt->i_private != NULL);
@@ -750,16 +791,20 @@ static int romfs_bind(FAR struct inode *blkdriver, const void *data,
struct romfs_mountpt_s *rm;
int ret;
+ fvdbg("Entry\n");
+
/* Open the block driver */
if (!blkdriver || !blkdriver->u.i_bops)
{
+ fdbg("No block driver/ops\n");
return -ENODEV;
}
if (blkdriver->u.i_bops->open &&
blkdriver->u.i_bops->open(blkdriver) != OK)
{
+ fdbg("No open method\n");
return -ENODEV;
}
@@ -768,6 +813,7 @@ static int romfs_bind(FAR struct inode *blkdriver, const void *data,
rm = (struct romfs_mountpt_s *)zalloc(sizeof(struct romfs_mountpt_s));
if (!rm)
{
+ fdbg("Failed to allocate mountpoint structure\n");
return -ENOMEM;
}
@@ -784,6 +830,7 @@ static int romfs_bind(FAR struct inode *blkdriver, const void *data,
ret = romfs_hwconfigure(rm);
if (ret < 0)
{
+ fdbg("romfs_hwconfigure failed: %d\n", ret);
goto errout_with_sem;
}
@@ -794,6 +841,7 @@ static int romfs_bind(FAR struct inode *blkdriver, const void *data,
ret = romfs_fsconfigure(rm);
if (ret < 0)
{
+ fdbg("romfs_fsconfigure failed: %d\n", ret);
goto errout_with_buffer;
}
@@ -828,10 +876,14 @@ static int romfs_unbind(void *handle, FAR struct inode **blkdriver)
struct romfs_mountpt_s *rm = (struct romfs_mountpt_s*)handle;
int ret;
+ fvdbg("Entry\n");
+
+#ifdef CONFIG_DEBUG
if (!rm)
{
return -EINVAL;
}
+#endif
/* Check if there are sill any files opened on the filesystem. */
@@ -841,6 +893,7 @@ static int romfs_unbind(void *handle, FAR struct inode **blkdriver)
{
/* We cannot unmount now.. there are open files */
+ fdbg("There are open files\n");
ret = -EBUSY;
}
else
@@ -897,6 +950,8 @@ static int romfs_statfs(struct inode *mountpt, struct statfs *buf)
struct romfs_mountpt_s *rm;
int ret;
+ fvdbg("Entry\n");
+
/* Sanity checks */
DEBUGASSERT(mountpt && mountpt->i_private);
@@ -911,7 +966,8 @@ static int romfs_statfs(struct inode *mountpt, struct statfs *buf)
ret = romfs_checkmount(rm);
if (ret < 0)
{
- goto errout_with_semaphore;
+ fdbg("romfs_checkmount failed: %d\n", ret);
+ goto errout_with_semaphore;
}
/* Fill in the statfs info */
@@ -951,6 +1007,8 @@ static int romfs_stat(struct inode *mountpt, const char *relpath, struct stat *b
struct romfs_dirinfo_s dirinfo;
int ret;
+ fvdbg("Entry\n");
+
/* Sanity checks */
DEBUGASSERT(mountpt && mountpt->i_private);
@@ -965,6 +1023,7 @@ static int romfs_stat(struct inode *mountpt, const char *relpath, struct stat *b
ret = romfs_checkmount(rm);
if (ret != OK)
{
+ fdbg("romfs_checkmount failed: %d\n", ret);
goto errout_with_semaphore;
}
@@ -976,6 +1035,7 @@ static int romfs_stat(struct inode *mountpt, const char *relpath, struct stat *b
if (ret < 0)
{
+ fvdbg("Failed to find directory: %d\n", ret);
goto errout_with_semaphore;
}
@@ -1004,6 +1064,7 @@ static int romfs_stat(struct inode *mountpt, const char *relpath, struct stat *b
{
/* Otherwise, pretend like the unsupported node does not exist */
+ fvdbg("Unsupported inode: %d\n", dirinfo.rd_next);
ret = -ENOENT;
goto errout_with_semaphore;
}
diff --git a/nuttx/fs/romfs/fs_romfsutil.c b/nuttx/fs/romfs/fs_romfsutil.c
index 39a33cccb..4f328f304 100644
--- a/nuttx/fs/romfs/fs_romfsutil.c
+++ b/nuttx/fs/romfs/fs_romfsutil.c
@@ -1,7 +1,7 @@
/****************************************************************************
* rm/romfs/fs_romfsutil.h
*
- * Copyright (C) 2008 Gregory Nutt. All rights reserved.
+ * Copyright (C) 2008-2009 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
*
* References: Linux/Documentation/filesystems/romfs.txt
@@ -445,6 +445,10 @@ int romfs_filecacheread(struct romfs_mountpt_s *rm, struct romfs_file_s *rf, uin
{
int ret;
+ fvdbg("sector: %d cached: %d sectorsize: %d XIP base: %p buffer: %p\n",
+ sector, rf->rf_cachesector, rm->rm_hwsectorsize,
+ rm->rm_xipbase, rf->rf_buffer);
+
/* rf->rf_cachesector holds the current sector that is buffer in or referenced
* by rf->rf_buffer. If the requested sector is the same as this sector,
* then we do nothing.
@@ -461,14 +465,17 @@ int romfs_filecacheread(struct romfs_mountpt_s *rm, struct romfs_file_s *rf, uin
*/
rf->rf_buffer = rm->rm_xipbase + sector * rm->rm_hwsectorsize;
+ fvdbg("XIP buffer: %p\n", rf->rf_buffer);
}
else
{
/* In non-XIP mode, we will have to read the new sector.*/
+ fvdbg("Calling romfs_hwread\n");
ret = romfs_hwread(rm, rf->rf_buffer, sector, 1);
if (ret < 0)
{
+ fdbg("romfs_hwread failed: %d\n", ret);
return ret;
}
}
@@ -623,7 +630,7 @@ int romfs_fileconfigure(struct romfs_mountpt_s *rm, struct romfs_file_s *rf)
/* We'll put a valid address in rf_buffer just in case. */
rf->rf_cachesector = 0;
- rf->rf_buffer = rm->rm_xipbase + rf->rf_startoffset;
+ rf->rf_buffer = rm->rm_xipbase;
}
else
{