<div>OK, some progress -</div><div>I temporarily modified ata.c to force C/H/S addressing for Compact Flash card (even though LBA status is set).</div><div>Now, I can read data and partition info from MBR. Partition info begins at offset 446, last two bytes are 0x55 and 0xAA, as expected.</div>
<div>Previously, under LBA mode, the entire MBR was read back as zeros, even when reading from LBA=0, or 63, etc. </div><div><br></div><div>After initialization, at RTEMS shell, the following info (reformatted) displays when fdisk is entered:</div>
<div><br></div><div>[/] # fdisk /dev/hda</div><div>PARTITION TABLE</div><div> BEGIN 63</div><div> END 7830144 </div><div> TYPE FAT 32</div><div> </div><div>This is consistent with Transcend 4GB card we are using, i.e, 7830144 * 512 = 4GB.</div>
<div><br></div><div>However, when attempting to mount, we get the following error:</div><div>fsmount: mounting of "/dev/hda1" to "/mnt/hda1" failed: Invalid argument</div><div>fsmount: mounting of "/dev/hda2" to "/mnt/hda2" failed: No such file or directory</div>
<div><br></div><div>The second error is expected, but not the first. </div><div><br></div><div>We get same error when we try to mount by command line, ie,</div><div><br></div><div>[/dev] # cd /</div><div>[/] # mkdir cf</div>
<div>[/] # mount -t dosfs /dev/hda /cf</div><div><br></div><div>!!! mount.c: no mount of base file system !!!</div><div>error: Invalid argument</div><div><br></div><div>fstable and relevant source lines are as follows:</div>
<div>////////////////////////////////////////////////////////////////////////////////</div><div>fstab_t fs_table[] = </div><div>{</div><div> {</div><div> "/dev/hda1", "/mnt/hda1", "dosfs",</div>
<div> RTEMS_FILESYSTEM_READ_WRITE,</div><div> FSMOUNT_MNT_OK | FSMOUNT_MNTPNT_CRTERR | FSMOUNT_MNT_FAILED,</div><div> 0</div><div> }</div><div>,</div><div> {</div><div> "/dev/hda2","/mnt/hda2", "dosfs",</div>
<div> RTEMS_FILESYSTEM_READ_WRITE,</div><div> FSMOUNT_MNT_OK | FSMOUNT_MNTPNT_CRTERR | FSMOUNT_MNT_FAILED,</div><div> 0</div><div> }</div><div>};</div><div>//////////////// from application initialization code ////////////////////////</div>
<div> </div><div> sc = rtems_bdpart_register_from_disk( "/dev/hda" );</div><div><br></div><div> rv = rtems_fsmount( fs_table, sizeof(fs_table)/sizeof(fs_table[0]), NULL);</div><div><br></div><div>////////////////////////////////////////////////////////////////////////////////</div>
<div><br></div><div>what are we doing wrong?</div><div><br></div><div>thanks in advance!</div><div><br></div><div>Chris Xenophontos</div><div><br></div><br><div class="gmail_quote">On Sun, Nov 4, 2012 at 10:24 PM, Chris Xenophontos <span dir="ltr"><<a href="mailto:cxenophontos@hammers.com" target="_blank">cxenophontos@hammers.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div>I retraced my steps, and I am still reading zeroes for all 512 bytes of first sector, which is supposed to be MBR(?). I'm not even seeing the 0xAA and 0x55 markers at end of sector. Does CF card need to be reformatted? Or is MBR located somewhere other than first sector?</div>
<div>thanks</div><span class="HOEnZb"><font color="#888888"><div>Chris </div></font></span><div class="HOEnZb"><div class="h5"><div><br></div><div> </div><div><br></div><div><br></div><br><div class="gmail_quote">On Fri, Nov 2, 2012 at 10:31 AM, Chris Xenophontos <span dir="ltr"><<a href="mailto:cxenophontos@hammers.com" target="_blank">cxenophontos@hammers.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">thanks Ric - I'll incorporate at next opportunity, and post back<div><span><font color="#888888">Chris </font></span><div>
<div><br><br><div class="gmail_quote">On Fri, Nov 2, 2012 at 1:44 AM, Claus, Ric <span dir="ltr"><<a href="mailto:claus@slac.stanford.edu" target="_blank">claus@slac.stanford.edu</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">I ran into the same kind of issue but with and SD card. The problem is that the files you're interested in are in the first partition, not in the MBR area of the disk. Thus you need to dereference the first partition descriptor found in the MBR to find the Volume ID (see <a href="http://www.pjrc.com/tech/8051/ide/fat32.html" target="_blank">http://www.pjrc.com/tech/8051/ide/fat32.html</a>), and use that to access your files. The following snippet of $RTEM_ROOT/src/cpukit/libmisc/fsmount/fsmount.h helped me to figure out what is going on:<br>
<br>
* The following example code tries to mount a FAT file system within a SD<br>
* Card. Some cards do not have a partition table so at first it tries to find<br>
* a file system inside the hole disk. If this is successful the mount process<br>
* will be aborted because the @ref RTEMS_FSTAB_OK condition is true. If this<br>
* did not work it tries to mount the file system inside the first partition.<br>
* If this fails the mount process will not be aborted (this is already the<br>
* last entry), but the last error status will be returned.<br>
*<br>
* @code<br>
* #include <stdio.h><br>
* #include <string.h><br>
* #include <errno.h><br>
*<br>
* #include <rtems.h><br>
* #include <rtems/bdpart.h><br>
* #include <rtems/error.h><br>
* #include <rtems/fsmount.h><br>
*<br>
* static const rtems_fstab_entry fstab [] = {<br>
* {<br>
* .source = "/dev/sd-card-a",<br>
* .target = "/mnt",<br>
* .type = "dosfs",<br>
* .options = RTEMS_FILESYSTEM_READ_WRITE,<br>
* .report_reasons = RTEMS_FSTAB_ANY,<br>
* .abort_reasons = RTEMS_FSTAB_OK<br>
* }, {<br>
* .source = "/dev/sd-card-a1",<br>
* .target = "/mnt",<br>
* .type = "dosfs",<br>
* .options = RTEMS_FILESYSTEM_READ_WRITE,<br>
* .report_reasons = RTEMS_FSTAB_ANY,<br>
* .abort_reasons = RTEMS_FSTAB_NONE<br>
* }<br>
* };<br>
*<br>
* static void my_mount(void)<br>
* {<br>
* rtems_status_code sc = RTEMS_SUCCESSFUL;<br>
* int rv = 0;<br>
* size_t abort_index = 0;<br>
*<br>
* sc = rtems_bdpart_register_from_disk("/dev/sd-card-a");<br>
* if (sc != RTEMS_SUCCESSFUL) {<br>
* printf("read partition table failed: %s\n", rtems_status_text(sc));<br>
* }<br>
*<br>
* rv = rtems_fsmount(fstab, sizeof(fstab) / sizeof(fstab [0]), &abort_index);<br>
* if (rv != 0) {<br>
* printf("mount failed: %s\n", strerror(errno));<br>
* }<br>
* printf("mount aborted at %zu\n", abort_index);<br>
* }<br>
* @endcode<br>
<br>
<br>
Cheers,<br>
Ric<br>
<br>
<br>
________________________________________<br>
From: <a href="mailto:rtems-users-bounces@rtems.org" target="_blank">rtems-users-bounces@rtems.org</a> [<a href="mailto:rtems-users-bounces@rtems.org" target="_blank">rtems-users-bounces@rtems.org</a>] On Behalf Of Chris Xenophontos [<a href="mailto:cxenophontos@hammers.com" target="_blank">cxenophontos@hammers.com</a>]<br>
Sent: Thursday, November 01, 2012 8:02 PM<br>
To: <a href="mailto:rtems-users@rtems.org" target="_blank">rtems-users@rtems.org</a><br>
Subject: File system and CompactFlash question on MCF5485EVB board<br>
<div><div><br>
We are currently running RTEMS 4.10.2 on a Coldfire MCF5485EVB board, with a Transcend 4GB Compact Flash Card installed in respective slot. The required manufacturer's firmware has been downloaded onto CPLD in order to access Compact Flash, etc.<br>
<br>
The Compact Flash socket is wired on the board to use 16-bit accesses, (both enables tied together), and memory mapped mode only.<br>
<br>
We want to use the Compact Flash card for file storage for our application, not for bootup.<br>
<br>
I've modified an existing ATA/IDE driver to access Compact Flash card, as directed in RTEMS File System documentation.<br>
<br>
The ATA driver initializes and reads Compact Flash card status correctly, and, when Identify Drive command is sent to card, the correct expected data is returned. First word is 0x848A, and driver correctly interprets cylinder/head/sector and LBA info - since these values translate into the card's capacity of 4GB. Logical Block Addressing is used.<br>
<br>
The problem we have is, during register and mount process, the file system attempts to read an MBR from the Compact Flash card - however, all zeroes are returned, and the process fails.<br>
<br>
When a file is written to CompactFlash card using a PC, it can be listed, etc, so the card appears to be OK. And because the Identify Device command causes the card to return expected data, the HW interface from our Coldfire board appears to be OK as well.<br>
<br>
Relevant parts from rtems.c are included below - any help is greatly appreciated!!<br>
<br>
thanks<br>
Chris Xenophontos<br>
<br>
#include <stdlib.h><br>
#include <rtems.h><br>
#include <bsp.h><br>
#include <unistd.h><br>
<br>
#include <rtems/rtems_bsdnet.h><br>
#include <rtems/libio.h><br>
#include <rtems/shellconfig.h> // added for shell/filesystem support<br>
#include <rtems/ide_part_table.h><br>
#include "networkconfig.h"<br>
#include <libchip/ide_ctrl_cfg.h><br>
#include <libchip/ide_ctrl_io.h><br>
#include <libchip/ata.h><br>
#include <rtems/bdpart.h><br>
#include <rtems/dosfs.h><br>
#include <rtems/fsmount.h><br>
<br>
rtems_task Init( rtems_task_argument ignored );<br>
extern int xmain( void );<br>
<br>
<br>
fstab_t fs_table[] =<br>
{<br>
{<br>
"/dev/hda","/mnt/cf", "dosfs",<br>
RTEMS_FILESYSTEM_READ_WRITE,<br>
FSMOUNT_MNT_OK | FSMOUNT_MNTPNT_CRTERR | FSMOUNT_MNT_FAILED,<br>
0<br>
}<br>
};<br>
<br>
<br>
<br>
rtems_task Init( rtems_task_argument ignored )<br>
{<br>
rtems_status_code sc;<br>
int rv;<br>
size_t abort_index;<br>
<br>
/* * * * * /<br>
<br>
abort_index = 0;<br>
<br>
sc = rtems_bdpart_register_from_disk( "/dev/hda" );<br>
<br>
rv = rtems_fsmount( fs_table, sizeof(fs_table)/sizeof(fs_table[0]), NULL);<br>
<br>
printf( "\n\nrtems_bdpart_register_from_disk status: %d\n", sc ); // returns 27 = IO_ERROR<br>
printf( "\nrtems_fsmount status status: %d\n", rv ); // return 0<br>
<br>
/* * * * * /<br>
<br>
sc = rtems_shell_init ( "fstst", 60 * 1024, 150, "/dev/console", 0, 1, 0 );<br>
<br>
/* * * * * /<br>
<br>
printf( "\nEntering xmain....\n" );<br>
<br>
xmain();<br>
};<br>
<br>
/* * * * * /<br>
<br>
#define TASK_INTLEVEL 0<br>
#define CONFIGURE_INIT<br>
#define CONFIGURE_INIT_TASK_ATTRIBUTES ( RTEMS_FLOATING_POINT | RTEMS_PREEMPT | RTEMS_NO_TIMESLICE | RTEMS_ASR | RTEMS_INTERRUPT_LEVEL(TASK_INTLEVEL))<br>
<br>
#define CONFIGURE_MAXIMUM_TASKS 20<br>
/*( SYS_MAX_TASKS + 7 ) */<br>
#define CONFIGURE_MAXIMUM_TIMERS 3<br>
<br>
<br>
#define CONFIGURE_MAXIMUM_SEMAPHORES 20 //12 // 16<br>
#define CONFIGURE_MAXIMUM_MESSAGE_QUEUES 24 //SB_MAX_PIPES=23 //32<br>
/* #define CONFIGURE_INIT_TASK_STACK_SIZE 2048 */<br>
<br>
#define CONFIGURE_INIT_TASK_STACK_SIZE (10*1024)<br>
#define CONFIGURE_INIT_TASK_PRIORITY 120<br>
#define CONFIGURE_INIT_TASK_INITIAL_MODES (RTEMS_PREEMPT | \<br>
RTEMS_NO_TIMESLICE | \<br>
RTEMS_NO_ASR | \<br>
RTEMS_INTERRUPT_LEVEL(0))<br>
<br>
#define ADA_TASKS 0<br>
<br>
#define CONFIGURE_RTEMS_INIT_TASKS_TABLE<br>
<br>
#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER<br>
<br>
#define CONFIGURE_MAXIMUM_DRIVERS 10<br>
#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER<br>
#define CONFIGURE_USE_IMFS_AS_BASE_FILESYSTEM<br>
#define CONFIGURE_LIBIO_MAXIMUM_FILE_DESCRIPTORS 30<br>
#define CONFIGURE_APPLICATION_NEEDS_LIBBLOCK<br>
#define CONFIGURE_FILESYSTEM_DOSFS<br>
<br>
#define CONFIGURE_APPLICATION_NEEDS_IDE_DRIVER<br>
#define CONFIGURE_APPLICATION_NEEDS_ATA_DRIVER<br>
#define CONFIGURE_ATA_DRIVER_TASK_PRIORITY 9<br>
#define CONFIGURE_BDBUF_MAX_WRITE_BLOCKS 512<br>
#define CONFIGURE_MICROSECONDS_PER_TICK 10000<br>
#define CONFIGURE_LIBIO_MAXIMUM_FILE_DESCRIPTORS 30<br>
<br>
#define CONFIGURE_SHELL_COMMANDS_INIT // added for shell/filesystem support<br>
#define CONFIGURE_SHELL_COMMANDS_ALL // added for shell/filesystem support<br>
<br>
////////////////////////////////////////////////////////////////<br>
#include <rtems/confdefs.h><br>
<br>
<br>
</div></div></blockquote></div><br></div></div></div>
</blockquote></div><br>
</div></div></blockquote></div><br>