Just a bit of cleanup, remove trailing whitespace mostly. No functional changes.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@24995 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
0eaadd30b2
commit
b8c45ca140
@ -45,7 +45,7 @@ status_t set_mime_type(vnode *node, const char *filename)
|
|||||||
|
|
||||||
if (filename[namelen-ext_len-1] != '.')
|
if (filename[namelen-ext_len-1] != '.')
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (!strcasecmp(filename + namelen - ext_len, p->extension))
|
if (!strcasecmp(filename + namelen - ext_len, p->extension))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -56,7 +56,7 @@ status_t set_mime_type(vnode *node, const char *filename)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_open_attrdir(fs_volume *_vol, fs_vnode *_node, void **_cookie)
|
dosfs_open_attrdir(fs_volume *_vol, fs_vnode *_node, void **_cookie)
|
||||||
{
|
{
|
||||||
nspace *vol = (nspace *)_vol->private_volume;
|
nspace *vol = (nspace *)_vol->private_volume;
|
||||||
@ -77,13 +77,14 @@ dosfs_open_attrdir(fs_volume *_vol, fs_vnode *_node, void **_cookie)
|
|||||||
return ENOMEM;
|
return ENOMEM;
|
||||||
}
|
}
|
||||||
*(int32 *)(*_cookie) = 0;
|
*(int32 *)(*_cookie) = 0;
|
||||||
|
|
||||||
UNLOCK_VOL(vol);
|
UNLOCK_VOL(vol);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t
|
|
||||||
|
status_t
|
||||||
dosfs_close_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
dosfs_close_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
||||||
{
|
{
|
||||||
nspace *vol = (nspace *)_vol->private_volume;
|
nspace *vol = (nspace *)_vol->private_volume;
|
||||||
@ -100,14 +101,14 @@ dosfs_close_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
|||||||
}
|
}
|
||||||
|
|
||||||
*(int32 *)_cookie = 1;
|
*(int32 *)_cookie = 1;
|
||||||
|
|
||||||
UNLOCK_VOL(vol);
|
UNLOCK_VOL(vol);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_free_attrdir_cookie(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
dosfs_free_attrdir_cookie(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
||||||
{
|
{
|
||||||
TOUCH(_vol); TOUCH(_node);
|
TOUCH(_vol); TOUCH(_node);
|
||||||
@ -126,7 +127,7 @@ dosfs_free_attrdir_cookie(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_rewind_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
dosfs_rewind_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
||||||
{
|
{
|
||||||
TOUCH(_vol); TOUCH(_node);
|
TOUCH(_vol); TOUCH(_node);
|
||||||
@ -143,8 +144,8 @@ dosfs_rewind_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_read_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
dosfs_read_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
||||||
struct dirent *entry, size_t bufsize, uint32 *num)
|
struct dirent *entry, size_t bufsize, uint32 *num)
|
||||||
{
|
{
|
||||||
nspace *vol = (nspace *)_vol->private_volume;
|
nspace *vol = (nspace *)_vol->private_volume;
|
||||||
@ -167,7 +168,7 @@ dosfs_read_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
|||||||
|
|
||||||
if ((*cookie == 0) && (node->mime)) {
|
if ((*cookie == 0) && (node->mime)) {
|
||||||
*num = 1;
|
*num = 1;
|
||||||
|
|
||||||
entry->d_ino = node->vnid;
|
entry->d_ino = node->vnid;
|
||||||
entry->d_dev = vol->id;
|
entry->d_dev = vol->id;
|
||||||
entry->d_reclen = 10;
|
entry->d_reclen = 10;
|
||||||
@ -177,7 +178,7 @@ dosfs_read_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
|||||||
*cookie = 1;
|
*cookie = 1;
|
||||||
|
|
||||||
UNLOCK_VOL(vol);
|
UNLOCK_VOL(vol);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -191,7 +192,7 @@ dosfs_open_attr(fs_volume *_vol, fs_vnode *_node, const char *name,
|
|||||||
|
|
||||||
if (strcmp(name, "BEOS:TYPE"))
|
if (strcmp(name, "BEOS:TYPE"))
|
||||||
return ENOENT;
|
return ENOENT;
|
||||||
|
|
||||||
LOCK_VOL(vol);
|
LOCK_VOL(vol);
|
||||||
|
|
||||||
if (node->mime == NULL) {
|
if (node->mime == NULL) {
|
||||||
@ -200,7 +201,7 @@ dosfs_open_attr(fs_volume *_vol, fs_vnode *_node, const char *name,
|
|||||||
}
|
}
|
||||||
|
|
||||||
UNLOCK_VOL(vol);
|
UNLOCK_VOL(vol);
|
||||||
|
|
||||||
*_cookie = &kBeOSTypeCookie;
|
*_cookie = &kBeOSTypeCookie;
|
||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
@ -220,7 +221,7 @@ dosfs_free_attr_cookie(fs_volume *_vol, fs_vnode *_node, void *cookie)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_read_attr_stat(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
dosfs_read_attr_stat(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
||||||
struct stat *stat)
|
struct stat *stat)
|
||||||
{
|
{
|
||||||
@ -244,7 +245,7 @@ dosfs_read_attr_stat(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
|||||||
UNLOCK_VOL(vol);
|
UNLOCK_VOL(vol);
|
||||||
return ENOENT;
|
return ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
stat->st_type = MIME_STRING_TYPE;
|
stat->st_type = MIME_STRING_TYPE;
|
||||||
stat->st_size = strlen(node->mime) + 1;
|
stat->st_size = strlen(node->mime) + 1;
|
||||||
|
|
||||||
@ -253,7 +254,7 @@ dosfs_read_attr_stat(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_read_attr(fs_volume *_vol, fs_vnode *_node, void *_cookie, off_t pos,
|
dosfs_read_attr(fs_volume *_vol, fs_vnode *_node, void *_cookie, off_t pos,
|
||||||
void *buffer, size_t *_length)
|
void *buffer, size_t *_length)
|
||||||
{
|
{
|
||||||
@ -264,7 +265,7 @@ dosfs_read_attr(fs_volume *_vol, fs_vnode *_node, void *_cookie, off_t pos,
|
|||||||
|
|
||||||
if (_cookie != &kBeOSTypeCookie)
|
if (_cookie != &kBeOSTypeCookie)
|
||||||
return ENOENT;
|
return ENOENT;
|
||||||
|
|
||||||
LOCK_VOL(vol);
|
LOCK_VOL(vol);
|
||||||
|
|
||||||
if (check_nspace_magic(vol, "dosfs_read_attr") ||
|
if (check_nspace_magic(vol, "dosfs_read_attr") ||
|
||||||
@ -291,6 +292,7 @@ dosfs_read_attr(fs_volume *_vol, fs_vnode *_node, void *_cookie, off_t pos,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// suck up application attempts to set mime types; this hides an unsightly
|
// suck up application attempts to set mime types; this hides an unsightly
|
||||||
// error message printed out by zip
|
// error message printed out by zip
|
||||||
status_t
|
status_t
|
||||||
@ -303,6 +305,6 @@ dosfs_write_attr(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
|||||||
|
|
||||||
if (_cookie != &kBeOSTypeCookie)
|
if (_cookie != &kBeOSTypeCookie)
|
||||||
return ENOSYS;
|
return ENOSYS;
|
||||||
|
|
||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
@ -14,7 +14,7 @@ status_t dosfs_close_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie);
|
|||||||
status_t dosfs_free_attrdir_cookie(fs_volume *_vol, fs_vnode *_node,
|
status_t dosfs_free_attrdir_cookie(fs_volume *_vol, fs_vnode *_node,
|
||||||
void *_cookie);
|
void *_cookie);
|
||||||
status_t dosfs_rewind_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie);
|
status_t dosfs_rewind_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie);
|
||||||
status_t dosfs_read_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
status_t dosfs_read_attrdir(fs_volume *_vol, fs_vnode *_node, void *_cookie,
|
||||||
struct dirent *buf, size_t bufsize, uint32 *num);
|
struct dirent *buf, size_t bufsize, uint32 *num);
|
||||||
status_t dosfs_open_attr(fs_volume *_vol, fs_vnode *_node, const char *name,
|
status_t dosfs_open_attr(fs_volume *_vol, fs_vnode *_node, const char *name,
|
||||||
int openMode, void **_cookie);
|
int openMode, void **_cookie);
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
This file may be used under the terms of the Be Sample Code License.
|
This file may be used under the terms of the Be Sample Code License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <KernelExport.h>
|
#include <KernelExport.h>
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
@ -90,7 +90,7 @@ _next_dirent_(struct diri *iter, struct _dirent_info_ *oinfo, char *filename,
|
|||||||
}
|
}
|
||||||
return ENOENT;
|
return ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (buffer[0] == 0xe5) { // skip erased entries
|
if (buffer[0] == 0xe5) { // skip erased entries
|
||||||
if (start_index != 0xffff) {
|
if (start_index != 0xffff) {
|
||||||
dprintf("lfn entry (%s) with intervening erased entries\n", filename);
|
dprintf("lfn entry (%s) with intervening erased entries\n", filename);
|
||||||
@ -99,9 +99,9 @@ _next_dirent_(struct diri *iter, struct _dirent_info_ *oinfo, char *filename,
|
|||||||
DPRINTF(2, ("entry erased, skipping...\n"));
|
DPRINTF(2, ("entry erased, skipping...\n"));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (buffer[0xb] == 0xf) { // long file name
|
if (buffer[0xb] == 0xf) { // long file name
|
||||||
if ((buffer[0xc] != 0) ||
|
if ((buffer[0xc] != 0) ||
|
||||||
(buffer[0x1a] != 0) || (buffer[0x1b] != 0)) {
|
(buffer[0x1a] != 0) || (buffer[0x1b] != 0)) {
|
||||||
dprintf("invalid long file name: reserved fields munged\n");
|
dprintf("invalid long file name: reserved fields munged\n");
|
||||||
continue;
|
continue;
|
||||||
@ -118,7 +118,7 @@ _next_dirent_(struct diri *iter, struct _dirent_info_ *oinfo, char *filename,
|
|||||||
for (i = 1; i < 0x20; i += 2) {
|
for (i = 1; i < 0x20; i += 2) {
|
||||||
if (*(uint16 *)&buffer[i] == 0xffff)
|
if (*(uint16 *)&buffer[i] == 0xffff)
|
||||||
break;
|
break;
|
||||||
*puni++ = *(uint16 *)&buffer[i];
|
*puni++ = *(uint16 *)&buffer[i];
|
||||||
if (i == 0x9) i+=3;
|
if (i == 0x9) i+=3;
|
||||||
if (i == 0x18) i+=2;
|
if (i == 0x18) i+=2;
|
||||||
}
|
}
|
||||||
@ -163,7 +163,7 @@ _next_dirent_(struct diri *iter, struct _dirent_info_ *oinfo, char *filename,
|
|||||||
// process long name
|
// process long name
|
||||||
if (start_index != 0xffff) {
|
if (start_index != 0xffff) {
|
||||||
if (lfn_count != 1) {
|
if (lfn_count != 1) {
|
||||||
dprintf("unfinished lfn in directory\n");
|
dprintf("unfinished lfn in directory\n");
|
||||||
start_index = 0xffff;
|
start_index = 0xffff;
|
||||||
} else {
|
} else {
|
||||||
if (unicode_to_utf8(uni, filename_len, (uint8*)filename, len)) {
|
if (unicode_to_utf8(uni, filename_len, (uint8*)filename, len)) {
|
||||||
@ -311,7 +311,7 @@ check_dir_empty(nspace *vol, vnode *dir)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
result = ENOTEMPTY;
|
result = ENOTEMPTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
diri_free(&iter);
|
diri_free(&iter);
|
||||||
@ -458,7 +458,7 @@ erase_dir_entry(nspace *vol, vnode *node)
|
|||||||
uint8 *buffer;
|
uint8 *buffer;
|
||||||
struct _dirent_info_ info;
|
struct _dirent_info_ info;
|
||||||
struct diri diri;
|
struct diri diri;
|
||||||
|
|
||||||
DPRINTF(0, ("erasing directory entries %lx through %lx\n",
|
DPRINTF(0, ("erasing directory entries %lx through %lx\n",
|
||||||
node->sindex, node->eindex));
|
node->sindex, node->eindex));
|
||||||
buffer = diri_init(vol,VNODE_PARENT_DIR_CLUSTER(node), node->sindex, &diri);
|
buffer = diri_init(vol,VNODE_PARENT_DIR_CLUSTER(node), node->sindex, &diri);
|
||||||
@ -474,7 +474,7 @@ erase_dir_entry(nspace *vol, vnode *node)
|
|||||||
|
|
||||||
if (result < 0)
|
if (result < 0)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
if (info.sindex != node->sindex || info.eindex != node->eindex) {
|
if (info.sindex != node->sindex || info.eindex != node->eindex) {
|
||||||
// any other attributes may be in a state of flux due to wstat calls
|
// any other attributes may be in a state of flux due to wstat calls
|
||||||
dprintf("erase_dir_entry: directory entry doesn't match\n");
|
dprintf("erase_dir_entry: directory entry doesn't match\n");
|
||||||
@ -564,7 +564,7 @@ find_short_name(nspace *vol, vnode *dir, const uchar *name)
|
|||||||
struct diri diri;
|
struct diri diri;
|
||||||
uint8 *buffer;
|
uint8 *buffer;
|
||||||
status_t result = ENOENT;
|
status_t result = ENOENT;
|
||||||
|
|
||||||
buffer = diri_init(vol, dir->cluster, 0, &diri);
|
buffer = diri_init(vol, dir->cluster, 0, &diri);
|
||||||
while (buffer) {
|
while (buffer) {
|
||||||
if (buffer[0] == 0)
|
if (buffer[0] == 0)
|
||||||
@ -669,7 +669,7 @@ _create_dir_entry_(nspace *vol, vnode *dir, struct _entry_info_ *info,
|
|||||||
// if at end of directory, last_entry flag will be true as it should be
|
// if at end of directory, last_entry flag will be true as it should be
|
||||||
|
|
||||||
diri_free(&diri);
|
diri_free(&diri);
|
||||||
|
|
||||||
if (error != B_OK && error != ENOENT)
|
if (error != B_OK && error != ENOENT)
|
||||||
return error;
|
return error;
|
||||||
|
|
||||||
@ -691,7 +691,7 @@ _create_dir_entry_(nspace *vol, vnode *dir, struct _entry_info_ *info,
|
|||||||
DPRINTF(0, ("_create_dir_entry_: out of space in root directory\n"));
|
DPRINTF(0, ("_create_dir_entry_: out of space in root directory\n"));
|
||||||
return ENOSPC;
|
return ENOSPC;
|
||||||
}
|
}
|
||||||
|
|
||||||
// otherwise grow directory to fit
|
// otherwise grow directory to fit
|
||||||
clusters_needed = ((*ne + 1) * 0x20 +
|
clusters_needed = ((*ne + 1) * 0x20 +
|
||||||
vol->bytes_per_sector*vol->sectors_per_cluster - 1) /
|
vol->bytes_per_sector*vol->sectors_per_cluster - 1) /
|
||||||
@ -759,7 +759,7 @@ _create_dir_entry_(nspace *vol, vnode *dir, struct _entry_info_ *info,
|
|||||||
buffer[0x1e] = (i >> 16) & 0xff;
|
buffer[0x1e] = (i >> 16) & 0xff;
|
||||||
buffer[0x1f] = (i >> 24) & 0xff;
|
buffer[0x1f] = (i >> 24) & 0xff;
|
||||||
diri_mark_dirty(&diri);
|
diri_mark_dirty(&diri);
|
||||||
|
|
||||||
if (last_entry) {
|
if (last_entry) {
|
||||||
// add end of directory markers to the rest of the
|
// add end of directory markers to the rest of the
|
||||||
// cluster; need to clear all the other entries or else
|
// cluster; need to clear all the other entries or else
|
||||||
@ -769,7 +769,7 @@ _create_dir_entry_(nspace *vol, vnode *dir, struct _entry_info_ *info,
|
|||||||
diri_mark_dirty(&diri);
|
diri_mark_dirty(&diri);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
diri_free(&diri);
|
diri_free(&diri);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -804,10 +804,10 @@ is_filename_legal(const char *name)
|
|||||||
{
|
{
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
unsigned int len = strlen(name);
|
unsigned int len = strlen(name);
|
||||||
|
|
||||||
if (len <= 0)
|
if (len <= 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// names ending with a dot are not allowed
|
// names ending with a dot are not allowed
|
||||||
if (name[len - 1] == '.')
|
if (name[len - 1] == '.')
|
||||||
return false;
|
return false;
|
||||||
@ -883,7 +883,7 @@ create_dir_entry(nspace *vol, vnode *dir, vnode *node, const char *name,
|
|||||||
error = B_OK;
|
error = B_OK;
|
||||||
else
|
else
|
||||||
error = find_short_name(vol, dir, nshort);
|
error = find_short_name(vol, dir, nshort);
|
||||||
|
|
||||||
if (error == B_OK) {
|
if (error == B_OK) {
|
||||||
do {
|
do {
|
||||||
memcpy(nshort, tshort, 11);
|
memcpy(nshort, tshort, 11);
|
||||||
@ -922,7 +922,7 @@ create_dir_entry(nspace *vol, vnode *dir, vnode *node, const char *name,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_read_vnode(fs_volume *_vol, ino_t vnid, fs_vnode *_node, int *_type,
|
dosfs_read_vnode(fs_volume *_vol, ino_t vnid, fs_vnode *_node, int *_type,
|
||||||
uint32 *_flags, bool reenter)
|
uint32 *_flags, bool reenter)
|
||||||
{
|
{
|
||||||
@ -980,7 +980,7 @@ dosfs_read_vnode(fs_volume *_vol, ino_t vnid, fs_vnode *_node, int *_type,
|
|||||||
result = ENOENT;
|
result = ENOENT;
|
||||||
goto bi;
|
goto bi;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
result = _next_dirent_(&iter, &info, filename, 512);
|
result = _next_dirent_(&iter, &info, filename, 512);
|
||||||
if (result < 0) {
|
if (result < 0) {
|
||||||
@ -1033,7 +1033,7 @@ dosfs_read_vnode(fs_volume *_vol, ino_t vnid, fs_vnode *_node, int *_type,
|
|||||||
* vol->sectors_per_cluster * vol->bytes_per_sector;
|
* vol->sectors_per_cluster * vol->bytes_per_sector;
|
||||||
}
|
}
|
||||||
if (entry->cluster) {
|
if (entry->cluster) {
|
||||||
entry->end_cluster = get_nth_fat_entry(vol, info.cluster,
|
entry->end_cluster = get_nth_fat_entry(vol, info.cluster,
|
||||||
(entry->st_size + vol->bytes_per_sector * vol->sectors_per_cluster - 1) /
|
(entry->st_size + vol->bytes_per_sector * vol->sectors_per_cluster - 1) /
|
||||||
vol->bytes_per_sector / vol->sectors_per_cluster - 1);
|
vol->bytes_per_sector / vol->sectors_per_cluster - 1);
|
||||||
} else
|
} else
|
||||||
@ -1064,7 +1064,7 @@ bi:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_walk(fs_volume *_vol, fs_vnode *_dir, const char *file, ino_t *_vnid)
|
dosfs_walk(fs_volume *_vol, fs_vnode *_dir, const char *file, ino_t *_vnid)
|
||||||
{
|
{
|
||||||
/* Starting at the base, find file in the subdir, and return path
|
/* Starting at the base, find file in the subdir, and return path
|
||||||
@ -1097,7 +1097,7 @@ dosfs_walk(fs_volume *_vol, fs_vnode *_dir, const char *file, ino_t *_vnid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_access(fs_volume *_vol, fs_vnode *_node, int mode)
|
dosfs_access(fs_volume *_vol, fs_vnode *_node, int mode)
|
||||||
{
|
{
|
||||||
status_t result = B_OK;
|
status_t result = B_OK;
|
||||||
@ -1133,7 +1133,7 @@ dosfs_access(fs_volume *_vol, fs_vnode *_node, int mode)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_readlink(fs_volume *_vol, fs_vnode *_node, char *buf, size_t *bufsize)
|
dosfs_readlink(fs_volume *_vol, fs_vnode *_node, char *buf, size_t *bufsize)
|
||||||
{
|
{
|
||||||
TOUCH(_vol); TOUCH(_node); TOUCH(buf); TOUCH(bufsize);
|
TOUCH(_vol); TOUCH(_node); TOUCH(buf); TOUCH(bufsize);
|
||||||
@ -1145,7 +1145,7 @@ dosfs_readlink(fs_volume *_vol, fs_vnode *_node, char *buf, size_t *bufsize)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_opendir(fs_volume *_vol, fs_vnode *_node, void **_cookie)
|
dosfs_opendir(fs_volume *_vol, fs_vnode *_node, void **_cookie)
|
||||||
{
|
{
|
||||||
nspace *vol = (nspace*)_vol->private_volume;
|
nspace *vol = (nspace*)_vol->private_volume;
|
||||||
@ -1190,7 +1190,7 @@ dosfs_opendir(fs_volume *_vol, fs_vnode *_node, void **_cookie)
|
|||||||
cookie->current_index = 0;
|
cookie->current_index = 0;
|
||||||
|
|
||||||
result = B_NO_ERROR;
|
result = B_NO_ERROR;
|
||||||
|
|
||||||
bi:
|
bi:
|
||||||
*_cookie = (void*)cookie;
|
*_cookie = (void*)cookie;
|
||||||
|
|
||||||
@ -1203,8 +1203,8 @@ bi:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_readdir(fs_volume *_vol, fs_vnode *_dir, void *_cookie,
|
dosfs_readdir(fs_volume *_vol, fs_vnode *_dir, void *_cookie,
|
||||||
struct dirent *entry, size_t bufsize, uint32 *num)
|
struct dirent *entry, size_t bufsize, uint32 *num)
|
||||||
{
|
{
|
||||||
int result = ENOENT;
|
int result = ENOENT;
|
||||||
@ -1214,7 +1214,7 @@ dosfs_readdir(fs_volume *_vol, fs_vnode *_dir, void *_cookie,
|
|||||||
struct diri diri;
|
struct diri diri;
|
||||||
|
|
||||||
LOCK_VOL(vol);
|
LOCK_VOL(vol);
|
||||||
|
|
||||||
if (check_nspace_magic(vol, "dosfs_readdir") ||
|
if (check_nspace_magic(vol, "dosfs_readdir") ||
|
||||||
check_vnode_magic(dir, "dosfs_readdir") ||
|
check_vnode_magic(dir, "dosfs_readdir") ||
|
||||||
check_dircookie_magic(cookie, "dosfs_readdir")) {
|
check_dircookie_magic(cookie, "dosfs_readdir")) {
|
||||||
@ -1260,7 +1260,7 @@ dosfs_readdir(fs_volume *_vol, fs_vnode *_dir, void *_cookie,
|
|||||||
|
|
||||||
if (dir->vnid == vol->root_vnode.vnid)
|
if (dir->vnid == vol->root_vnode.vnid)
|
||||||
cookie->current_index += 2;
|
cookie->current_index += 2;
|
||||||
|
|
||||||
if (result == B_NO_ERROR) {
|
if (result == B_NO_ERROR) {
|
||||||
*num = 1;
|
*num = 1;
|
||||||
entry->d_dev = vol->id;
|
entry->d_dev = vol->id;
|
||||||
@ -1282,7 +1282,7 @@ bi:
|
|||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_rewinddir(fs_volume *_vol, fs_vnode *_node, void* _cookie)
|
dosfs_rewinddir(fs_volume *_vol, fs_vnode *_node, void* _cookie)
|
||||||
@ -1310,7 +1310,7 @@ dosfs_rewinddir(fs_volume *_vol, fs_vnode *_node, void* _cookie)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_closedir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
dosfs_closedir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
||||||
{
|
{
|
||||||
TOUCH(_vol); TOUCH(_node); TOUCH(_cookie);
|
TOUCH(_vol); TOUCH(_node); TOUCH(_cookie);
|
||||||
@ -1321,7 +1321,7 @@ dosfs_closedir(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_free_dircookie(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
dosfs_free_dircookie(fs_volume *_vol, fs_vnode *_node, void *_cookie)
|
||||||
{
|
{
|
||||||
nspace *vol = (nspace *)_vol->private_volume;
|
nspace *vol = (nspace *)_vol->private_volume;
|
||||||
|
@ -12,13 +12,13 @@ status_t findfile_case(nspace *vol, vnode *dir, const char *file,
|
|||||||
status_t findfile_nocase(nspace *vol, vnode *dir, const char *file,
|
status_t findfile_nocase(nspace *vol, vnode *dir, const char *file,
|
||||||
ino_t *vnid, vnode **node);
|
ino_t *vnid, vnode **node);
|
||||||
status_t findfile_nocase_duplicates(nspace *vol, vnode *dir, const char *file,
|
status_t findfile_nocase_duplicates(nspace *vol, vnode *dir, const char *file,
|
||||||
ino_t *vnid, vnode **node, bool *dups_exist);
|
ino_t *vnid, vnode **node, bool *dups_exist);
|
||||||
status_t findfile_case_duplicates(nspace *vol, vnode *dir, const char *file,
|
status_t findfile_case_duplicates(nspace *vol, vnode *dir, const char *file,
|
||||||
ino_t *vnid, vnode **node, bool *dups_exist);
|
ino_t *vnid, vnode **node, bool *dups_exist);
|
||||||
status_t erase_dir_entry(nspace *vol, vnode *node);
|
status_t erase_dir_entry(nspace *vol, vnode *node);
|
||||||
status_t compact_directory(nspace *vol, vnode *dir);
|
status_t compact_directory(nspace *vol, vnode *dir);
|
||||||
status_t create_volume_label(nspace *vol, const char name[11], uint32 *index);
|
status_t create_volume_label(nspace *vol, const char name[11], uint32 *index);
|
||||||
status_t create_dir_entry(nspace *vol, vnode *dir, vnode *node,
|
status_t create_dir_entry(nspace *vol, vnode *dir, vnode *node,
|
||||||
const char *name, uint32 *ns, uint32 *ne);
|
const char *name, uint32 *ns, uint32 *ne);
|
||||||
|
|
||||||
status_t dosfs_read_vnode(fs_volume *_vol, ino_t vnid, fs_vnode *_node,
|
status_t dosfs_read_vnode(fs_volume *_vol, ino_t vnid, fs_vnode *_node,
|
||||||
|
@ -335,12 +335,12 @@ mount_fat_disk(const char *path, fs_volume *_vol, const int flags,
|
|||||||
of sectors. They say that they have 196576 sectors but they
|
of sectors. They say that they have 196576 sectors but they
|
||||||
really only have 196192. This check is a work-around for their
|
really only have 196192. This check is a work-around for their
|
||||||
brain-deadness.
|
brain-deadness.
|
||||||
*/
|
*/
|
||||||
unsigned char bogus_zip_data[] = {
|
unsigned char bogus_zip_data[] = {
|
||||||
0x00, 0x02, 0x04, 0x01, 0x00, 0x02, 0x00, 0x02, 0x00, 0x00,
|
0x00, 0x02, 0x04, 0x01, 0x00, 0x02, 0x00, 0x02, 0x00, 0x00,
|
||||||
0xf8, 0xc0, 0x00, 0x20, 0x00, 0x40, 0x00, 0x20, 0x00, 0x00
|
0xf8, 0xc0, 0x00, 0x20, 0x00, 0x40, 0x00, 0x20, 0x00, 0x00
|
||||||
};
|
};
|
||||||
|
|
||||||
if (memcmp(buf+0x0b, bogus_zip_data, sizeof(bogus_zip_data)) == 0 &&
|
if (memcmp(buf+0x0b, bogus_zip_data, sizeof(bogus_zip_data)) == 0 &&
|
||||||
vol->total_sectors == 196576 &&
|
vol->total_sectors == 196576 &&
|
||||||
((off_t)geo.sectors_per_track *
|
((off_t)geo.sectors_per_track *
|
||||||
@ -370,8 +370,8 @@ mount_fat_disk(const char *path, fs_volume *_vol, const int flags,
|
|||||||
vol->root_vnode.st_size = vol->root_sectors * vol->bytes_per_sector;
|
vol->root_vnode.st_size = vol->root_sectors * vol->bytes_per_sector;
|
||||||
|
|
||||||
vol->data_start = vol->root_start + vol->root_sectors;
|
vol->data_start = vol->root_start + vol->root_sectors;
|
||||||
vol->total_clusters = (vol->total_sectors - vol->data_start) / vol->sectors_per_cluster;
|
vol->total_clusters = (vol->total_sectors - vol->data_start) / vol->sectors_per_cluster;
|
||||||
|
|
||||||
// XXX: uncertain about border cases; win32 sdk says cutoffs are at
|
// XXX: uncertain about border cases; win32 sdk says cutoffs are at
|
||||||
// at ff6/ff7 (or fff6/fff7), but that doesn't make much sense
|
// at ff6/ff7 (or fff6/fff7), but that doesn't make much sense
|
||||||
if (vol->total_clusters > 0xff1)
|
if (vol->total_clusters > 0xff1)
|
||||||
@ -389,7 +389,7 @@ mount_fat_disk(const char *path, fs_volume *_vol, const int flags,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// perform sanity checks on the FAT
|
// perform sanity checks on the FAT
|
||||||
|
|
||||||
// the media descriptor in active FAT should match the one in the BPB
|
// the media descriptor in active FAT should match the one in the BPB
|
||||||
if ((err = read_pos(vol->fd, vol->bytes_per_sector*(vol->reserved_sectors + vol->active_fat * vol->sectors_per_fat), (void *)buf, 0x200)) != 0x200) {
|
if ((err = read_pos(vol->fd, vol->bytes_per_sector*(vol->reserved_sectors + vol->active_fat * vol->sectors_per_fat), (void *)buf, 0x200)) != 0x200) {
|
||||||
dprintf("dosfs: error reading FAT\n");
|
dprintf("dosfs: error reading FAT\n");
|
||||||
@ -417,7 +417,7 @@ mount_fat_disk(const char *path, fs_volume *_vol, const int flags,
|
|||||||
dprintf("dosfs error: media descriptor mismatch in fat # %ld (%x != %x)\n", i, buf2[0], vol->media_descriptor);
|
dprintf("dosfs error: media descriptor mismatch in fat # %ld (%x != %x)\n", i, buf2[0], vol->media_descriptor);
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
#if 0
|
#if 0
|
||||||
// checking for exact matches of fats is too
|
// checking for exact matches of fats is too
|
||||||
// restrictive; allow these to go through in
|
// restrictive; allow these to go through in
|
||||||
// case the fat is corrupted for some reason
|
// case the fat is corrupted for some reason
|
||||||
@ -474,13 +474,13 @@ mount_fat_disk(const char *path, fs_volume *_vol, const int flags,
|
|||||||
uint32 free_count, last_allocated;
|
uint32 free_count, last_allocated;
|
||||||
err = get_fsinfo(vol, &free_count, &last_allocated);
|
err = get_fsinfo(vol, &free_count, &last_allocated);
|
||||||
if (err >= 0) {
|
if (err >= 0) {
|
||||||
if (free_count < vol->total_clusters)
|
if (free_count < vol->total_clusters)
|
||||||
vol->free_clusters = free_count;
|
vol->free_clusters = free_count;
|
||||||
else {
|
else {
|
||||||
dprintf("free cluster count from fsinfo block invalid %lx\n", free_count);
|
dprintf("free cluster count from fsinfo block invalid %lx\n", free_count);
|
||||||
err = -1;
|
err = -1;
|
||||||
}
|
}
|
||||||
if (last_allocated < vol->total_clusters)
|
if (last_allocated < vol->total_clusters)
|
||||||
vol->last_allocated = last_allocated; //update to a closer match
|
vol->last_allocated = last_allocated; //update to a closer match
|
||||||
}
|
}
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
@ -541,7 +541,7 @@ mount_fat_disk(const char *path, fs_volume *_vol, const int flags,
|
|||||||
if (!memcmp(vol->vol_label, "__RO__ ", 11)) {
|
if (!memcmp(vol->vol_label, "__RO__ ", 11)) {
|
||||||
vol->flags |= B_FS_IS_READONLY;
|
vol->flags |= B_FS_IS_READONLY;
|
||||||
}
|
}
|
||||||
|
|
||||||
*newVol = vol;
|
*newVol = vol;
|
||||||
return B_NO_ERROR;
|
return B_NO_ERROR;
|
||||||
|
|
||||||
@ -584,7 +584,7 @@ dosfs_identify_partition(int fd, partition_data *partition, void **_cookie)
|
|||||||
uint32 sectors_per_fat;
|
uint32 sectors_per_fat;
|
||||||
char name[12];
|
char name[12];
|
||||||
identify_cookie *cookie;
|
identify_cookie *cookie;
|
||||||
|
|
||||||
// read in the boot sector
|
// read in the boot sector
|
||||||
if (read_pos(fd, 0, (void*)buf, 512) != 512) {
|
if (read_pos(fd, 0, (void*)buf, 512) != 512) {
|
||||||
return -1;
|
return -1;
|
||||||
@ -638,7 +638,7 @@ dosfs_identify_partition(int fd, partition_data *partition, void **_cookie)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cookie = (identify_cookie *)malloc(sizeof(identify_cookie));
|
cookie = (identify_cookie *)malloc(sizeof(identify_cookie));
|
||||||
if (!cookie)
|
if (!cookie)
|
||||||
return -1;
|
return -1;
|
||||||
@ -729,11 +729,11 @@ dosfs_mount(fs_volume *_vol, const char *device, uint32 flags,
|
|||||||
char name[32];
|
char name[32];
|
||||||
|
|
||||||
if (check_nspace_magic(vol, "dosfs_mount")) return EINVAL;
|
if (check_nspace_magic(vol, "dosfs_mount")) return EINVAL;
|
||||||
|
|
||||||
*_rootID = vol->root_vnode.vnid;
|
*_rootID = vol->root_vnode.vnid;
|
||||||
_vol->private_volume = (void *)vol;
|
_vol->private_volume = (void *)vol;
|
||||||
_vol->ops = &gFATVolumeOps;
|
_vol->ops = &gFATVolumeOps;
|
||||||
|
|
||||||
// You MUST do this. Create the vnode for the root.
|
// You MUST do this. Create the vnode for the root.
|
||||||
result = publish_vnode(_vol, *_rootID, (void*)&(vol->root_vnode),
|
result = publish_vnode(_vol, *_rootID, (void*)&(vol->root_vnode),
|
||||||
&gFATVnodeOps, make_mode(vol, &vol->root_vnode), 0);
|
&gFATVnodeOps, make_mode(vol, &vol->root_vnode), 0);
|
||||||
@ -776,7 +776,7 @@ update_fsinfo(nspace *vol)
|
|||||||
&& (vol->flags & B_FS_IS_READONLY) == 0) {
|
&& (vol->flags & B_FS_IS_READONLY) == 0) {
|
||||||
uchar *buffer;
|
uchar *buffer;
|
||||||
int32 tid = cache_start_transaction(vol->fBlockCache);
|
int32 tid = cache_start_transaction(vol->fBlockCache);
|
||||||
if ((buffer = (uchar *)block_cache_get_writable_etc(vol->fBlockCache,
|
if ((buffer = (uchar *)block_cache_get_writable_etc(vol->fBlockCache,
|
||||||
vol->fsinfo_sector, 0, vol->bytes_per_sector, tid)) != NULL) {
|
vol->fsinfo_sector, 0, vol->bytes_per_sector, tid)) != NULL) {
|
||||||
if ((read32(buffer,0) == 0x41615252) && (read32(buffer,0x1e4) == 0x61417272) && (read16(buffer,0x1fe) == 0xaa55)) {
|
if ((read32(buffer,0) == 0x41615252) && (read32(buffer,0x1e4) == 0x61417272) && (read16(buffer,0x1fe) == 0xaa55)) {
|
||||||
//number of free clusters
|
//number of free clusters
|
||||||
@ -784,7 +784,7 @@ update_fsinfo(nspace *vol)
|
|||||||
buffer[0x1e9] = ((vol->free_clusters >> 8) & 0xff);
|
buffer[0x1e9] = ((vol->free_clusters >> 8) & 0xff);
|
||||||
buffer[0x1ea] = ((vol->free_clusters >> 16) & 0xff);
|
buffer[0x1ea] = ((vol->free_clusters >> 16) & 0xff);
|
||||||
buffer[0x1eb] = ((vol->free_clusters >> 24) & 0xff);
|
buffer[0x1eb] = ((vol->free_clusters >> 24) & 0xff);
|
||||||
//cluster number of most recently allocated cluster
|
//cluster number of most recently allocated cluster
|
||||||
buffer[0x1ec] = (vol->last_allocated & 0xff);
|
buffer[0x1ec] = (vol->last_allocated & 0xff);
|
||||||
buffer[0x1ed] = ((vol->last_allocated >> 8) & 0xff);
|
buffer[0x1ed] = ((vol->last_allocated >> 8) & 0xff);
|
||||||
buffer[0x1ee] = ((vol->last_allocated >> 16) & 0xff);
|
buffer[0x1ee] = ((vol->last_allocated >> 16) & 0xff);
|
||||||
@ -804,19 +804,21 @@ update_fsinfo(nspace *vol)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static status_t get_fsinfo(nspace *vol, uint32 *free_count, uint32 *last_allocated)
|
|
||||||
|
static status_t
|
||||||
|
get_fsinfo(nspace *vol, uint32 *free_count, uint32 *last_allocated)
|
||||||
{
|
{
|
||||||
uchar *buffer;
|
uchar *buffer;
|
||||||
int32 result;
|
int32 result;
|
||||||
|
|
||||||
if ((vol->fat_bits != 32) || (vol->fsinfo_sector == 0xffff))
|
if ((vol->fat_bits != 32) || (vol->fsinfo_sector == 0xffff))
|
||||||
return B_ERROR;
|
return B_ERROR;
|
||||||
|
|
||||||
if ((buffer = (uchar *)block_cache_get_etc(vol->fBlockCache, vol->fsinfo_sector, 0, vol->bytes_per_sector)) == NULL) {
|
if ((buffer = (uchar *)block_cache_get_etc(vol->fBlockCache, vol->fsinfo_sector, 0, vol->bytes_per_sector)) == NULL) {
|
||||||
dprintf("get_fsinfo: error getting fsinfo sector %x\n", vol->fsinfo_sector);
|
dprintf("get_fsinfo: error getting fsinfo sector %x\n", vol->fsinfo_sector);
|
||||||
return EIO;
|
return EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((read32(buffer,0) == 0x41615252) && (read32(buffer,0x1e4) == 0x61417272) && (read16(buffer,0x1fe) == 0xaa55)) {
|
if ((read32(buffer,0) == 0x41615252) && (read32(buffer,0x1e4) == 0x61417272) && (read16(buffer,0x1fe) == 0xaa55)) {
|
||||||
*free_count = read32(buffer,0x1e8);
|
*free_count = read32(buffer,0x1e8);
|
||||||
*last_allocated = read32(buffer,0x1ec);
|
*last_allocated = read32(buffer,0x1ec);
|
||||||
@ -831,7 +833,7 @@ static status_t get_fsinfo(nspace *vol, uint32 *free_count, uint32 *last_allocat
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static status_t
|
static status_t
|
||||||
dosfs_unmount(fs_volume *_vol)
|
dosfs_unmount(fs_volume *_vol)
|
||||||
{
|
{
|
||||||
int result = B_NO_ERROR;
|
int result = B_NO_ERROR;
|
||||||
@ -839,16 +841,16 @@ dosfs_unmount(fs_volume *_vol)
|
|||||||
nspace* vol = (nspace*)_vol->private_volume;
|
nspace* vol = (nspace*)_vol->private_volume;
|
||||||
|
|
||||||
LOCK_VOL(vol);
|
LOCK_VOL(vol);
|
||||||
|
|
||||||
if (check_nspace_magic(vol, "dosfs_unmount")) {
|
if (check_nspace_magic(vol, "dosfs_unmount")) {
|
||||||
UNLOCK_VOL(vol);
|
UNLOCK_VOL(vol);
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
DPRINTF(0, ("dosfs_unmount volume %lx\n", vol->id));
|
DPRINTF(0, ("dosfs_unmount volume %lx\n", vol->id));
|
||||||
|
|
||||||
update_fsinfo(vol);
|
update_fsinfo(vol);
|
||||||
|
|
||||||
// Unlike in BeOS, we need to put the reference to our root node ourselves
|
// Unlike in BeOS, we need to put the reference to our root node ourselves
|
||||||
put_vnode(_vol, vol->root_vnode.vnid);
|
put_vnode(_vol, vol->root_vnode.vnid);
|
||||||
block_cache_delete(vol->fBlockCache, true);
|
block_cache_delete(vol->fBlockCache, true);
|
||||||
@ -880,8 +882,9 @@ dosfs_unmount(fs_volume *_vol)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// dosfs_read_fs_stat - Fill in fs_info struct for device.
|
// dosfs_read_fs_stat - Fill in fs_info struct for device.
|
||||||
static status_t
|
static status_t
|
||||||
dosfs_read_fs_stat(fs_volume *_vol, struct fs_info * fss)
|
dosfs_read_fs_stat(fs_volume *_vol, struct fs_info * fss)
|
||||||
{
|
{
|
||||||
nspace* vol = (nspace*)_vol->private_volume;
|
nspace* vol = (nspace*)_vol->private_volume;
|
||||||
@ -897,16 +900,16 @@ dosfs_read_fs_stat(fs_volume *_vol, struct fs_info * fss)
|
|||||||
DPRINTF(1, ("dosfs_read_fs_stat called\n"));
|
DPRINTF(1, ("dosfs_read_fs_stat called\n"));
|
||||||
|
|
||||||
// fss->dev and fss->root filled in by kernel
|
// fss->dev and fss->root filled in by kernel
|
||||||
|
|
||||||
// File system flags.
|
// File system flags.
|
||||||
fss->flags = vol->flags;
|
fss->flags = vol->flags;
|
||||||
|
|
||||||
// FS block size.
|
// FS block size.
|
||||||
fss->block_size = vol->bytes_per_sector * vol->sectors_per_cluster;
|
fss->block_size = vol->bytes_per_sector * vol->sectors_per_cluster;
|
||||||
|
|
||||||
// IO size - specifies buffer size for file copying
|
// IO size - specifies buffer size for file copying
|
||||||
fss->io_size = 65536;
|
fss->io_size = 65536;
|
||||||
|
|
||||||
// Total blocks
|
// Total blocks
|
||||||
fss->total_blocks = vol->total_clusters;
|
fss->total_blocks = vol->total_clusters;
|
||||||
|
|
||||||
@ -933,12 +936,13 @@ dosfs_read_fs_stat(fs_volume *_vol, struct fs_info * fss)
|
|||||||
|
|
||||||
// File system name
|
// File system name
|
||||||
strcpy(fss->fsh_name, "fat");
|
strcpy(fss->fsh_name, "fat");
|
||||||
|
|
||||||
UNLOCK_VOL(vol);
|
UNLOCK_VOL(vol);
|
||||||
|
|
||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static status_t
|
static status_t
|
||||||
dosfs_write_fs_stat(fs_volume *_vol, const struct fs_info * fss, uint32 mask)
|
dosfs_write_fs_stat(fs_volume *_vol, const struct fs_info * fss, uint32 mask)
|
||||||
{
|
{
|
||||||
@ -1025,18 +1029,18 @@ dosfs_write_fs_stat(fs_volume *_vol, const struct fs_info * fss, uint32 mask)
|
|||||||
if (result == 0)
|
if (result == 0)
|
||||||
memcpy(vol->vol_label, name, 11);
|
memcpy(vol->vol_label, name, 11);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vol->fs_flags & FS_FLAGS_OP_SYNC)
|
if (vol->fs_flags & FS_FLAGS_OP_SYNC)
|
||||||
_dosfs_sync(vol);
|
_dosfs_sync(vol);
|
||||||
|
|
||||||
bi: UNLOCK_VOL(vol);
|
bi: UNLOCK_VOL(vol);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static status_t
|
static status_t
|
||||||
dosfs_ioctl(fs_volume *_vol, fs_vnode *_node, void *cookie, ulong code,
|
dosfs_ioctl(fs_volume *_vol, fs_vnode *_node, void *cookie, ulong code,
|
||||||
void *buf, size_t len)
|
void *buf, size_t len)
|
||||||
{
|
{
|
||||||
status_t result = B_OK;
|
status_t result = B_OK;
|
||||||
@ -1079,7 +1083,7 @@ dosfs_ioctl(fs_volume *_vol, fs_vnode *_node, void *cookie, ulong code,
|
|||||||
dprintf("root vnode id = %Lx\n", vol->root_vnode.vnid);
|
dprintf("root vnode id = %Lx\n", vol->root_vnode.vnid);
|
||||||
dprintf("volume label [%11.11s]\n", vol->vol_label);
|
dprintf("volume label [%11.11s]\n", vol->vol_label);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 100001 :
|
case 100001 :
|
||||||
dprintf("vnode id %Lx, dir vnid = %Lx\n", node->vnid, node->dir_vnid);
|
dprintf("vnode id %Lx, dir vnid = %Lx\n", node->vnid, node->dir_vnid);
|
||||||
dprintf("si = %lx, ei = %lx\n", node->sindex, node->eindex);
|
dprintf("si = %lx, ei = %lx\n", node->sindex, node->eindex);
|
||||||
@ -1131,12 +1135,12 @@ dosfs_ioctl(fs_volume *_vol, fs_vnode *_node, void *cookie, ulong code,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
_dosfs_sync(nspace *vol)
|
_dosfs_sync(nspace *vol)
|
||||||
{
|
{
|
||||||
if (check_nspace_magic(vol, "dosfs_sync"))
|
if (check_nspace_magic(vol, "dosfs_sync"))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
update_fsinfo(vol);
|
update_fsinfo(vol);
|
||||||
block_cache_sync(vol->fBlockCache);
|
block_cache_sync(vol->fBlockCache);
|
||||||
|
|
||||||
@ -1144,14 +1148,14 @@ _dosfs_sync(nspace *vol)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static status_t
|
static status_t
|
||||||
dosfs_sync(fs_volume *_vol)
|
dosfs_sync(fs_volume *_vol)
|
||||||
{
|
{
|
||||||
nspace *vol = (nspace *)_vol->private_volume;
|
nspace *vol = (nspace *)_vol->private_volume;
|
||||||
status_t err;
|
status_t err;
|
||||||
|
|
||||||
DPRINTF(0, ("dosfs_sync called on volume %lx\n", vol->id));
|
DPRINTF(0, ("dosfs_sync called on volume %lx\n", vol->id));
|
||||||
|
|
||||||
LOCK_VOL(vol);
|
LOCK_VOL(vol);
|
||||||
err = _dosfs_sync(vol);
|
err = _dosfs_sync(vol);
|
||||||
UNLOCK_VOL(vol);
|
UNLOCK_VOL(vol);
|
||||||
@ -1160,7 +1164,7 @@ dosfs_sync(fs_volume *_vol)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static status_t
|
static status_t
|
||||||
dosfs_fsync(fs_volume *_vol, fs_vnode *_node)
|
dosfs_fsync(fs_volume *_vol, fs_vnode *_node)
|
||||||
{
|
{
|
||||||
nspace *vol = (nspace *)_vol->private_volume;
|
nspace *vol = (nspace *)_vol->private_volume;
|
||||||
|
@ -84,7 +84,7 @@ typedef struct vnode {
|
|||||||
* on the disk (or at least in the cache) so that get_next_dirent continues
|
* on the disk (or at least in the cache) so that get_next_dirent continues
|
||||||
* to function properly
|
* to function properly
|
||||||
*/
|
*/
|
||||||
uint32 sindex, eindex; // starting and ending index of directory entry
|
uint32 sindex, eindex; // starting and ending index of directory entry
|
||||||
uint32 cluster; // starting cluster of the data
|
uint32 cluster; // starting cluster of the data
|
||||||
uint32 mode; // dos-style attributes
|
uint32 mode; // dos-style attributes
|
||||||
off_t st_size; // in bytes
|
off_t st_size; // in bytes
|
||||||
@ -98,7 +98,7 @@ typedef struct vnode {
|
|||||||
|
|
||||||
#if TRACK_FILENAME
|
#if TRACK_FILENAME
|
||||||
char *filename;
|
char *filename;
|
||||||
#endif
|
#endif
|
||||||
} vnode;
|
} vnode;
|
||||||
|
|
||||||
// mode bits
|
// mode bits
|
||||||
@ -122,7 +122,7 @@ typedef struct _nspace
|
|||||||
char device[256];
|
char device[256];
|
||||||
uint32 flags; // see <fcntl.be.h> for modes
|
uint32 flags; // see <fcntl.be.h> for modes
|
||||||
void *fBlockCache;
|
void *fBlockCache;
|
||||||
|
|
||||||
// info from bpb
|
// info from bpb
|
||||||
uint32 bytes_per_sector;
|
uint32 bytes_per_sector;
|
||||||
uint32 sectors_per_cluster;
|
uint32 sectors_per_cluster;
|
||||||
|
@ -570,7 +570,7 @@ const uint16 sjis81tou[] = {
|
|||||||
0x6DC6, 0x6DEC, 0x6DDE, 0x6DCC, 0x6DE8, 0x6DD2, 0x6DC5, 0x6DFA, 0x6DD9, 0x6DE4, 0x6DD5, 0x6DEA, 0x6DEE, 0x6E2D, 0x6E6E, 0x6E2E,
|
0x6DC6, 0x6DEC, 0x6DDE, 0x6DCC, 0x6DE8, 0x6DD2, 0x6DC5, 0x6DFA, 0x6DD9, 0x6DE4, 0x6DD5, 0x6DEA, 0x6DEE, 0x6E2D, 0x6E6E, 0x6E2E,
|
||||||
0x6E19, 0x6E72, 0x6E5F, 0x6E3E, 0x6E23, 0x6E6B, 0x6E2B, 0x6E76, 0x6E4D, 0x6E1F, 0x6E43, 0x6E3A, 0x6E4E, 0x6E24, 0x6EFF, 0x6E1D,
|
0x6E19, 0x6E72, 0x6E5F, 0x6E3E, 0x6E23, 0x6E6B, 0x6E2B, 0x6E76, 0x6E4D, 0x6E1F, 0x6E43, 0x6E3A, 0x6E4E, 0x6E24, 0x6EFF, 0x6E1D,
|
||||||
0x6E38, 0x6E82, 0x6EAA, 0x6E98, 0x6EC9, 0x6EB7, 0x6ED3, 0x6EBD, 0x6EAF, 0x6EC4, 0x6EB2, 0x6ED4, 0x6ED5, 0x6E8F, 0x6EA5, 0x6EC2,
|
0x6E38, 0x6E82, 0x6EAA, 0x6E98, 0x6EC9, 0x6EB7, 0x6ED3, 0x6EBD, 0x6EAF, 0x6EC4, 0x6EB2, 0x6ED4, 0x6ED5, 0x6E8F, 0x6EA5, 0x6EC2,
|
||||||
0x6E9F, 0x6F41, 0x6F11, 0x704C, 0x6EEC, 0x6EF8, 0x6EFE, 0x6F3F, 0x6EF2, 0x6F31, 0x6EEF, 0x6F32, 0x6ECC, 0x0000, 0x0000, 0x0000,
|
0x6E9F, 0x6F41, 0x6F11, 0x704C, 0x6EEC, 0x6EF8, 0x6EFE, 0x6F3F, 0x6EF2, 0x6F31, 0x6EEF, 0x6F32, 0x6ECC, 0x0000, 0x0000, 0x0000,
|
||||||
0xFFFF
|
0xFFFF
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -830,7 +830,7 @@ const uint16 sjise0tou[] = {
|
|||||||
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
|
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
|
||||||
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
|
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
|
||||||
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
|
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
|
||||||
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
|
0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000, 0x0000,
|
||||||
0xFFFF
|
0xFFFF
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -871,7 +871,7 @@ const table_segment sjistables[] = { {sjis00tou, 0x0000},
|
|||||||
str[3] = 0x80 | (val&0x3f);\
|
str[3] = 0x80 | (val&0x3f);\
|
||||||
uni_str += 2; str += 4;\
|
uni_str += 2; str += 4;\
|
||||||
}\
|
}\
|
||||||
}
|
}
|
||||||
|
|
||||||
// Pierre's Uber Macro
|
// Pierre's Uber Macro
|
||||||
#define u_hostendian_to_utf8(str, uni_str)\
|
#define u_hostendian_to_utf8(str, uni_str)\
|
||||||
@ -925,7 +925,7 @@ const table_segment sjistables[] = { {sjis00tou, 0x0000},
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Count the number of bytes of a UTF-8 character
|
// Count the number of bytes of a UTF-8 character
|
||||||
#define utf8_char_len(c) ((((int32)0xE5000000 >> ((c >> 3) & 0x1E)) & 3) + 1)
|
#define utf8_char_len(c) ((((int32)0xE5000000 >> ((c >> 3) & 0x1E)) & 3) + 1)
|
||||||
|
|
||||||
// converts LENDIAN unicode to utf8
|
// converts LENDIAN unicode to utf8
|
||||||
static status_t
|
static status_t
|
||||||
@ -939,7 +939,7 @@ _lendian_unicode_to_utf8(
|
|||||||
int32 dstLimit = *dstLen;
|
int32 dstLimit = *dstLen;
|
||||||
int32 srcCount = 0;
|
int32 srcCount = 0;
|
||||||
int32 dstCount = 0;
|
int32 dstCount = 0;
|
||||||
|
|
||||||
for (srcCount = 0; srcCount < srcLimit; srcCount += 2) {
|
for (srcCount = 0; srcCount < srcLimit; srcCount += 2) {
|
||||||
uint16 *UNICODE = (uint16 *)&src[srcCount];
|
uint16 *UNICODE = (uint16 *)&src[srcCount];
|
||||||
uchar utf8[4];
|
uchar utf8[4];
|
||||||
@ -965,7 +965,7 @@ _lendian_unicode_to_utf8(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// utf8 to LENDIAN unicode
|
// utf8 to LENDIAN unicode
|
||||||
static status_t
|
static status_t
|
||||||
_utf8_to_lendian_unicode(
|
_utf8_to_lendian_unicode(
|
||||||
const char *src,
|
const char *src,
|
||||||
int32 *srcLen,
|
int32 *srcLen,
|
||||||
@ -984,7 +984,7 @@ _utf8_to_lendian_unicode(
|
|||||||
int err_flag;
|
int err_flag;
|
||||||
|
|
||||||
if ((srcCount + utf8_char_len(src[srcCount])) > srcLimit)
|
if ((srcCount + utf8_char_len(src[srcCount])) > srcLimit)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
utf8_to_u_hostendian(UTF8, UNICODE, err_flag);
|
utf8_to_u_hostendian(UTF8, UNICODE, err_flag);
|
||||||
if(err_flag == 1)
|
if(err_flag == 1)
|
||||||
@ -1023,10 +1023,10 @@ _one_to_utf8(
|
|||||||
uint16 *UNICODE = &unicode;
|
uint16 *UNICODE = &unicode;
|
||||||
uchar utf8[4];
|
uchar utf8[4];
|
||||||
uchar *UTF8 = utf8;
|
uchar *UTF8 = utf8;
|
||||||
|
|
||||||
*(uint32 *)utf8 = 0;
|
*(uint32 *)utf8 = 0;
|
||||||
u_hostendian_to_utf8(UTF8, UNICODE);
|
u_hostendian_to_utf8(UTF8, UNICODE);
|
||||||
|
|
||||||
int32 utf8Len = UTF8 - utf8;
|
int32 utf8Len = UTF8 - utf8;
|
||||||
if ((dstCount + utf8Len) > dstLimit)
|
if ((dstCount + utf8Len) > dstLimit)
|
||||||
break;
|
break;
|
||||||
@ -1057,13 +1057,13 @@ _utf8_to_sjis_bendian(
|
|||||||
|
|
||||||
while ((srcCount < srcLimit) && (dstCount < dstLimit)) {
|
while ((srcCount < srcLimit) && (dstCount < dstLimit)) {
|
||||||
if ((srcCount + utf8_char_len(src[srcCount])) > srcLimit)
|
if ((srcCount + utf8_char_len(src[srcCount])) > srcLimit)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
uint16 unicode;
|
uint16 unicode;
|
||||||
uint16 *UNICODE = &unicode;
|
uint16 *UNICODE = &unicode;
|
||||||
int err_flag;
|
int err_flag;
|
||||||
bool multibyte = false;
|
bool multibyte = false;
|
||||||
const uint16 *table = NULL;
|
const uint16 *table = NULL;
|
||||||
uchar *UTF8 = (uchar *)src + srcCount;
|
uchar *UTF8 = (uchar *)src + srcCount;
|
||||||
|
|
||||||
utf8_to_u_hostendian(UTF8, UNICODE, err_flag);
|
utf8_to_u_hostendian(UTF8, UNICODE, err_flag);
|
||||||
@ -1077,7 +1077,7 @@ _utf8_to_sjis_bendian(
|
|||||||
uint16 offset = sjistables[t].offset;
|
uint16 offset = sjistables[t].offset;
|
||||||
|
|
||||||
if (offset == 0x0000)
|
if (offset == 0x0000)
|
||||||
dst[dstCount] = i;
|
dst[dstCount] = i;
|
||||||
else {
|
else {
|
||||||
if ((dstCount + 1) < dstLimit) {
|
if ((dstCount + 1) < dstLimit) {
|
||||||
uint16 sjis = offset + i;
|
uint16 sjis = offset + i;
|
||||||
@ -1127,7 +1127,7 @@ inline bool is_initial_sjis_byte(uchar c)
|
|||||||
|
|
||||||
// takes a unicode name of unilen uchar's and converts to a utf8 name of at
|
// takes a unicode name of unilen uchar's and converts to a utf8 name of at
|
||||||
// most utf8len uint8's
|
// most utf8len uint8's
|
||||||
status_t unicode_to_utf8(const uchar *uni, uint32 unilen, uint8 *utf8,
|
status_t unicode_to_utf8(const uchar *uni, uint32 unilen, uint8 *utf8,
|
||||||
uint32 utf8len)
|
uint32 utf8len)
|
||||||
{
|
{
|
||||||
status_t result;
|
status_t result;
|
||||||
@ -1259,7 +1259,7 @@ status_t munge_short_name_sjis(uchar nshort[11], uint64 value)
|
|||||||
if (nshort[i] == ' ') break;
|
if (nshort[i] == ' ') break;
|
||||||
if (is_initial_sjis_byte(nshort[i])) i++;
|
if (is_initial_sjis_byte(nshort[i])) i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(nshort + last, buffer, len);
|
memcpy(nshort + last, buffer, len);
|
||||||
memset(nshort + last + len, ' ', 8 - (last + len));
|
memset(nshort + last + len, ' ', 8 - (last + len));
|
||||||
|
|
||||||
@ -1459,8 +1459,8 @@ bi:
|
|||||||
dprintf("generate_short_name_sjis error: %lx (%s)\n", result, strerror(result));
|
dprintf("generate_short_name_sjis error: %lx (%s)\n", result, strerror(result));
|
||||||
}
|
}
|
||||||
|
|
||||||
free(sjis);
|
free(sjis);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1514,7 +1514,7 @@ status_t msdos_to_utf8(uchar *msdos, uchar *utf8, uint32 utf8len, bool toLower)
|
|||||||
pos = 0;
|
pos = 0;
|
||||||
for (i=0;i<8;i++) {
|
for (i=0;i<8;i++) {
|
||||||
if (msdos[i] == ' ') break;
|
if (msdos[i] == ' ') break;
|
||||||
normalized[pos++] = ((i == 0) && (msdos[i] == 5)) ? 0xe5 :
|
normalized[pos++] = ((i == 0) && (msdos[i] == 5)) ? 0xe5 :
|
||||||
(toLower ? tolower(msdos[i]) : msdos[i]);
|
(toLower ? tolower(msdos[i]) : msdos[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1539,24 +1539,24 @@ bool requires_munged_short_name(const uchar *utf8name, const uchar nshort[11], i
|
|||||||
int i, len;
|
int i, len;
|
||||||
|
|
||||||
if (encoding != MS_DOS_CONVERSION) return true;
|
if (encoding != MS_DOS_CONVERSION) return true;
|
||||||
|
|
||||||
for ( ; *utf8name != 0; utf8name++) {
|
for ( ; *utf8name != 0; utf8name++) {
|
||||||
if (!BEGINS_UTF8CHAR(*utf8name)) continue;
|
if (!BEGINS_UTF8CHAR(*utf8name)) continue;
|
||||||
if (*utf8name == '.') break;
|
if (*utf8name == '.') break;
|
||||||
leading++;
|
leading++;
|
||||||
if (leading > 8) return true;
|
if (leading > 8) return true;
|
||||||
if ((nshort[leading - 1] == '_') && (*utf8name != '_')) return true;
|
if ((nshort[leading - 1] == '_') && (*utf8name != '_')) return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*utf8name != 0) {
|
if (*utf8name != 0) {
|
||||||
utf8name++;
|
utf8name++;
|
||||||
|
|
||||||
for ( ; *utf8name != 0; utf8name++) {
|
for ( ; *utf8name != 0; utf8name++) {
|
||||||
if (!BEGINS_UTF8CHAR(*utf8name)) continue;
|
if (!BEGINS_UTF8CHAR(*utf8name)) continue;
|
||||||
if (*utf8name == '.') return true;
|
if (*utf8name == '.') return true;
|
||||||
trailing++;
|
trailing++;
|
||||||
if (trailing > 3) return true;
|
if (trailing > 3) return true;
|
||||||
if ((nshort[leading + trailing - 1] == '_') && (*utf8name != '_')) return true;
|
if ((nshort[leading + trailing - 1] == '_') && (*utf8name != '_')) return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1567,7 +1567,7 @@ bool requires_munged_short_name(const uchar *utf8name, const uchar nshort[11], i
|
|||||||
for (i = 8, len = 0; i < 11; i++)
|
for (i = 8, len = 0; i < 11; i++)
|
||||||
if (nshort[i] != ' ') len++;
|
if (nshort[i] != ' ') len++;
|
||||||
if (len != trailing) return true;
|
if (len != trailing) return true;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
Copyright 1999-2001, Be Incorporated. All Rights Reserved.
|
Copyright 1999-2001, Be Incorporated. All Rights Reserved.
|
||||||
This file may be used under the terms of the Be Sample Code License.
|
This file may be used under the terms of the Be Sample Code License.
|
||||||
*/
|
*/
|
||||||
#include <KernelExport.h>
|
#include <KernelExport.h>
|
||||||
|
|
||||||
#include <fs_cache.h>
|
#include <fs_cache.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
@ -21,16 +21,17 @@
|
|||||||
|
|
||||||
#define DPRINTF(a,b) if (debug_fat > (a)) dprintf b
|
#define DPRINTF(a,b) if (debug_fat > (a)) dprintf b
|
||||||
|
|
||||||
static status_t mirror_fats(nspace *vol, uint32 sector, uint8 *buffer, int32 tid)
|
static status_t
|
||||||
|
mirror_fats(nspace *vol, uint32 sector, uint8 *buffer, int32 tid)
|
||||||
{
|
{
|
||||||
uint32 i;
|
uint32 i;
|
||||||
char *buf = buffer;
|
char *buf = buffer;
|
||||||
|
|
||||||
if (!vol->fat_mirrored)
|
if (!vol->fat_mirrored)
|
||||||
return B_OK;
|
return B_OK;
|
||||||
|
|
||||||
sector -= vol->active_fat * vol->sectors_per_fat;
|
sector -= vol->active_fat * vol->sectors_per_fat;
|
||||||
|
|
||||||
for (i=0;i<vol->fat_count;i++) {
|
for (i=0;i<vol->fat_count;i++) {
|
||||||
char *blockData;
|
char *blockData;
|
||||||
if (i == vol->active_fat)
|
if (i == vol->active_fat)
|
||||||
@ -40,11 +41,13 @@ static status_t mirror_fats(nspace *vol, uint32 sector, uint8 *buffer, int32 tid
|
|||||||
buf += vol->bytes_per_sector;
|
buf += vol->bytes_per_sector;
|
||||||
block_cache_put(vol->fBlockCache, sector + i*vol->sectors_per_fat);
|
block_cache_put(vol->fBlockCache, sector + i*vol->sectors_per_fat);
|
||||||
}
|
}
|
||||||
|
|
||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32 _count_free_clusters_fat32(nspace *vol)
|
|
||||||
|
static int32
|
||||||
|
_count_free_clusters_fat32(nspace *vol)
|
||||||
{
|
{
|
||||||
int32 count = 0;
|
int32 count = 0;
|
||||||
const uint8 *block;
|
const uint8 *block;
|
||||||
@ -53,7 +56,7 @@ static int32 _count_free_clusters_fat32(nspace *vol)
|
|||||||
uint32 cur_sector;
|
uint32 cur_sector;
|
||||||
|
|
||||||
cur_sector = vol->reserved_sectors + vol->active_fat * vol->sectors_per_fat;
|
cur_sector = vol->reserved_sectors + vol->active_fat * vol->sectors_per_fat;
|
||||||
|
|
||||||
for(fat_sector = 0; fat_sector < vol->sectors_per_fat; fat_sector++) {
|
for(fat_sector = 0; fat_sector < vol->sectors_per_fat; fat_sector++) {
|
||||||
block = (uint8 *)block_cache_get(vol->fBlockCache, cur_sector);
|
block = (uint8 *)block_cache_get(vol->fBlockCache, cur_sector);
|
||||||
if(block == NULL) {
|
if(block == NULL) {
|
||||||
@ -79,7 +82,8 @@ static int32 _count_free_clusters_fat32(nspace *vol)
|
|||||||
|
|
||||||
enum { _IOCTL_COUNT_FREE_, _IOCTL_GET_ENTRY_, _IOCTL_SET_ENTRY_, _IOCTL_ALLOCATE_N_ENTRIES_ };
|
enum { _IOCTL_COUNT_FREE_, _IOCTL_GET_ENTRY_, _IOCTL_SET_ENTRY_, _IOCTL_ALLOCATE_N_ENTRIES_ };
|
||||||
|
|
||||||
static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, int32 _tid)
|
static int32
|
||||||
|
_fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, int32 _tid)
|
||||||
{
|
{
|
||||||
int32 result = 0;
|
int32 result = 0;
|
||||||
uint32 n = 0, first = 0, last = 0;
|
uint32 n = 0, first = 0, last = 0;
|
||||||
@ -97,15 +101,15 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
if (check_nspace_magic(vol, "_fat_ioctl_")) return EINVAL;
|
if (check_nspace_magic(vol, "_fat_ioctl_")) return EINVAL;
|
||||||
|
|
||||||
DPRINTF(3, ("_fat_ioctl_: action %lx, cluster %lx, N %lx\n", action, cluster, N));
|
DPRINTF(3, ("_fat_ioctl_: action %lx, cluster %lx, N %lx\n", action, cluster, N));
|
||||||
|
|
||||||
if (action == _IOCTL_COUNT_FREE_) {
|
if (action == _IOCTL_COUNT_FREE_) {
|
||||||
if(vol->fat_bits == 32)
|
if(vol->fat_bits == 32)
|
||||||
// use a optimized version of the cluster counting algorithms
|
// use a optimized version of the cluster counting algorithms
|
||||||
return _count_free_clusters_fat32(vol);
|
return _count_free_clusters_fat32(vol);
|
||||||
else
|
else
|
||||||
cluster = 2;
|
cluster = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (action == _IOCTL_ALLOCATE_N_ENTRIES_)
|
if (action == _IOCTL_ALLOCATE_N_ENTRIES_)
|
||||||
cluster = vol->last_allocated;
|
cluster = vol->last_allocated;
|
||||||
|
|
||||||
@ -120,7 +124,7 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
sector = vol->reserved_sectors + vol->active_fat * vol->sectors_per_fat +
|
sector = vol->reserved_sectors + vol->active_fat * vol->sectors_per_fat +
|
||||||
off / vol->bytes_per_sector;
|
off / vol->bytes_per_sector;
|
||||||
off %= vol->bytes_per_sector;
|
off %= vol->bytes_per_sector;
|
||||||
|
|
||||||
if (action != _IOCTL_SET_ENTRY_ && action != _IOCTL_ALLOCATE_N_ENTRIES_) {
|
if (action != _IOCTL_SET_ENTRY_ && action != _IOCTL_ALLOCATE_N_ENTRIES_) {
|
||||||
block1 = (uint8 *)block_cache_get(vol->fBlockCache, sector);
|
block1 = (uint8 *)block_cache_get(vol->fBlockCache, sector);
|
||||||
} else {
|
} else {
|
||||||
@ -128,12 +132,12 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
tid = cache_start_transaction(vol->fBlockCache);
|
tid = cache_start_transaction(vol->fBlockCache);
|
||||||
block1 = (uint8 *)block_cache_get_writable(vol->fBlockCache, sector, tid);
|
block1 = (uint8 *)block_cache_get_writable(vol->fBlockCache, sector, tid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (block1 == NULL) {
|
if (block1 == NULL) {
|
||||||
DPRINTF(0, ("_fat_ioctl_: error reading fat (sector %lx)\n", sector));
|
DPRINTF(0, ("_fat_ioctl_: error reading fat (sector %lx)\n", sector));
|
||||||
return EIO;
|
return EIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i=0;i<vol->total_clusters;i++) {
|
for (i=0;i<vol->total_clusters;i++) {
|
||||||
ASSERT(IS_DATA_CLUSTER(cluster));
|
ASSERT(IS_DATA_CLUSTER(cluster));
|
||||||
ASSERT(off == ((cluster * vol->fat_bits / 8) % vol->bytes_per_sector));
|
ASSERT(off == ((cluster * vol->fat_bits / 8) % vol->bytes_per_sector));
|
||||||
@ -144,7 +148,7 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
block2 = (uint8 *)block_cache_get(vol->fBlockCache, ++sector);
|
block2 = (uint8 *)block_cache_get(vol->fBlockCache, ++sector);
|
||||||
else
|
else
|
||||||
block2 = (uint8 *)block_cache_get_writable(vol->fBlockCache, ++sector, tid);
|
block2 = (uint8 *)block_cache_get_writable(vol->fBlockCache, ++sector, tid);
|
||||||
|
|
||||||
if (block2 == NULL) {
|
if (block2 == NULL) {
|
||||||
DPRINTF(0, ("_fat_ioctl_: error reading fat (sector %lx)\n", sector));
|
DPRINTF(0, ("_fat_ioctl_: error reading fat (sector %lx)\n", sector));
|
||||||
result = EIO;
|
result = EIO;
|
||||||
@ -186,7 +190,7 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
block1[off+1] |= (ormask >> 8);
|
block1[off+1] |= (ormask >> 8);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (off == vol->bytes_per_sector - 1) {
|
if (off == vol->bytes_per_sector - 1) {
|
||||||
off = (cluster & 1) ? 1 : 0;
|
off = (cluster & 1) ? 1 : 0;
|
||||||
block_cache_put(vol->fBlockCache, sector - 1);
|
block_cache_put(vol->fBlockCache, sector - 1);
|
||||||
@ -216,7 +220,7 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
}
|
}
|
||||||
if (((action == _IOCTL_ALLOCATE_N_ENTRIES_) && (val == 0)) ||
|
if (((action == _IOCTL_ALLOCATE_N_ENTRIES_) && (val == 0)) ||
|
||||||
(action == _IOCTL_SET_ENTRY_)) {
|
(action == _IOCTL_SET_ENTRY_)) {
|
||||||
ASSERT((V & 0xf0000000) == 0);
|
ASSERT((V & 0xf0000000) == 0);
|
||||||
*(uint32 *)&block1[off] = B_HOST_TO_LENDIAN_INT32(V);
|
*(uint32 *)&block1[off] = B_HOST_TO_LENDIAN_INT32(V);
|
||||||
// block1[off] = V & 0xff;
|
// block1[off] = V & 0xff;
|
||||||
// block1[off+1] = (V >> 8) & 0xff;
|
// block1[off+1] = (V >> 8) & 0xff;
|
||||||
@ -265,7 +269,7 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
// iterate cluster and sector if needed
|
// iterate cluster and sector if needed
|
||||||
if (++cluster == vol->total_clusters + 2) {
|
if (++cluster == vol->total_clusters + 2) {
|
||||||
block_cache_put(vol->fBlockCache, sector);
|
block_cache_put(vol->fBlockCache, sector);
|
||||||
|
|
||||||
cluster = 2;
|
cluster = 2;
|
||||||
off = 2 * vol->fat_bits / 8;
|
off = 2 * vol->fat_bits / 8;
|
||||||
sector = vol->reserved_sectors + vol->active_fat * vol->sectors_per_fat;
|
sector = vol->reserved_sectors + vol->active_fat * vol->sectors_per_fat;
|
||||||
@ -278,17 +282,17 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
|
|
||||||
if (off >= vol->bytes_per_sector) {
|
if (off >= vol->bytes_per_sector) {
|
||||||
block_cache_put(vol->fBlockCache, sector);
|
block_cache_put(vol->fBlockCache, sector);
|
||||||
|
|
||||||
off -= vol->bytes_per_sector;
|
off -= vol->bytes_per_sector;
|
||||||
sector++;
|
sector++;
|
||||||
ASSERT(sector < vol->reserved_sectors + (vol->active_fat + 1) * vol->sectors_per_fat);
|
ASSERT(sector < vol->reserved_sectors + (vol->active_fat + 1) * vol->sectors_per_fat);
|
||||||
|
|
||||||
if (action != _IOCTL_SET_ENTRY_ && action != _IOCTL_ALLOCATE_N_ENTRIES_)
|
if (action != _IOCTL_SET_ENTRY_ && action != _IOCTL_ALLOCATE_N_ENTRIES_)
|
||||||
block1 = (uint8 *)block_cache_get(vol->fBlockCache, sector);
|
block1 = (uint8 *)block_cache_get(vol->fBlockCache, sector);
|
||||||
else
|
else
|
||||||
block1 = (uint8 *)block_cache_get_writable(vol->fBlockCache, sector, tid);
|
block1 = (uint8 *)block_cache_get_writable(vol->fBlockCache, sector, tid);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (block1 == NULL) {
|
if (block1 == NULL) {
|
||||||
DPRINTF(0, ("_fat_ioctl_: error reading fat (sector %lx)\n", sector));
|
DPRINTF(0, ("_fat_ioctl_: error reading fat (sector %lx)\n", sector));
|
||||||
result = EIO;
|
result = EIO;
|
||||||
@ -297,7 +301,7 @@ static int32 _fat_ioctl_(nspace *vol, uint32 action, uint32 cluster, int32 N, in
|
|||||||
}
|
}
|
||||||
|
|
||||||
bi:
|
bi:
|
||||||
if (block1)
|
if (block1)
|
||||||
block_cache_put(vol->fBlockCache, sector);
|
block_cache_put(vol->fBlockCache, sector);
|
||||||
if (_tid == -1 && tid > 0)
|
if (_tid == -1 && tid > 0)
|
||||||
cache_end_transaction(vol->fBlockCache, tid, NULL, NULL);
|
cache_end_transaction(vol->fBlockCache, tid, NULL, NULL);
|
||||||
@ -323,12 +327,16 @@ bi:
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
int32 count_free_clusters(nspace *vol)
|
|
||||||
|
int32
|
||||||
|
count_free_clusters(nspace *vol)
|
||||||
{
|
{
|
||||||
return _fat_ioctl_(vol, _IOCTL_COUNT_FREE_, 0, 0, -1);
|
return _fat_ioctl_(vol, _IOCTL_COUNT_FREE_, 0, 0, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int32 get_fat_entry(nspace *vol, uint32 cluster)
|
|
||||||
|
static int32
|
||||||
|
get_fat_entry(nspace *vol, uint32 cluster)
|
||||||
{
|
{
|
||||||
int32 value = _fat_ioctl_(vol, _IOCTL_GET_ENTRY_, cluster, 0, -1);
|
int32 value = _fat_ioctl_(vol, _IOCTL_GET_ENTRY_, cluster, 0, -1);
|
||||||
|
|
||||||
@ -340,7 +348,7 @@ static int32 get_fat_entry(nspace *vol, uint32 cluster)
|
|||||||
|
|
||||||
if (value > 0x0ffffff7)
|
if (value > 0x0ffffff7)
|
||||||
return END_FAT_ENTRY;
|
return END_FAT_ENTRY;
|
||||||
|
|
||||||
if (value > 0x0ffffff0)
|
if (value > 0x0ffffff0)
|
||||||
return BAD_FAT_ENTRY;
|
return BAD_FAT_ENTRY;
|
||||||
|
|
||||||
@ -348,13 +356,17 @@ static int32 get_fat_entry(nspace *vol, uint32 cluster)
|
|||||||
return BAD_FAT_ENTRY;
|
return BAD_FAT_ENTRY;
|
||||||
}
|
}
|
||||||
|
|
||||||
static status_t set_fat_entry(nspace *vol, uint32 cluster, int32 value)
|
|
||||||
|
static status_t
|
||||||
|
set_fat_entry(nspace *vol, uint32 cluster, int32 value)
|
||||||
{
|
{
|
||||||
return _fat_ioctl_(vol, _IOCTL_SET_ENTRY_, cluster, value, -1);
|
return _fat_ioctl_(vol, _IOCTL_SET_ENTRY_, cluster, value, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// traverse n fat entries
|
// traverse n fat entries
|
||||||
int32 get_nth_fat_entry(nspace *vol, int32 cluster, uint32 n)
|
int32
|
||||||
|
get_nth_fat_entry(nspace *vol, int32 cluster, uint32 n)
|
||||||
{
|
{
|
||||||
if (check_nspace_magic(vol, "get_nth_fat_entry")) return EINVAL;
|
if (check_nspace_magic(vol, "get_nth_fat_entry")) return EINVAL;
|
||||||
|
|
||||||
@ -366,19 +378,21 @@ int32 get_nth_fat_entry(nspace *vol, int32 cluster, uint32 n)
|
|||||||
}
|
}
|
||||||
|
|
||||||
ASSERT(cluster != 0);
|
ASSERT(cluster != 0);
|
||||||
|
|
||||||
return cluster;
|
return cluster;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// count number of clusters in fat chain starting at given cluster
|
// count number of clusters in fat chain starting at given cluster
|
||||||
// should only be used for calculating directory sizes because it doesn't
|
// should only be used for calculating directory sizes because it doesn't
|
||||||
// return proper error codes
|
// return proper error codes
|
||||||
uint32 count_clusters(nspace *vol, int32 cluster)
|
uint32
|
||||||
|
count_clusters(nspace *vol, int32 cluster)
|
||||||
{
|
{
|
||||||
int32 count = 0;
|
int32 count = 0;
|
||||||
|
|
||||||
DPRINTF(2, ("count_clusters %lx\n", cluster));
|
DPRINTF(2, ("count_clusters %lx\n", cluster));
|
||||||
|
|
||||||
if (check_nspace_magic(vol, "count_clusters")) return 0;
|
if (check_nspace_magic(vol, "count_clusters")) return 0;
|
||||||
|
|
||||||
// not intended for use on root directory
|
// not intended for use on root directory
|
||||||
@ -408,7 +422,9 @@ uint32 count_clusters(nspace *vol, int32 cluster)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t clear_fat_chain(nspace *vol, uint32 cluster)
|
|
||||||
|
status_t
|
||||||
|
clear_fat_chain(nspace *vol, uint32 cluster)
|
||||||
{
|
{
|
||||||
int32 c;
|
int32 c;
|
||||||
status_t result;
|
status_t result;
|
||||||
@ -442,7 +458,9 @@ status_t clear_fat_chain(nspace *vol, uint32 cluster)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t allocate_n_fat_entries(nspace *vol, int32 n, int32 *start)
|
|
||||||
|
status_t
|
||||||
|
allocate_n_fat_entries(nspace *vol, int32 n, int32 *start)
|
||||||
{
|
{
|
||||||
int32 c;
|
int32 c;
|
||||||
|
|
||||||
@ -463,13 +481,15 @@ status_t allocate_n_fat_entries(nspace *vol, int32 n, int32 *start)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t set_fat_chain_length(nspace *vol, vnode *node, uint32 clusters)
|
|
||||||
|
status_t
|
||||||
|
set_fat_chain_length(nspace *vol, vnode *node, uint32 clusters)
|
||||||
{
|
{
|
||||||
status_t result;
|
status_t result;
|
||||||
int32 i, c, n;
|
int32 i, c, n;
|
||||||
|
|
||||||
DPRINTF(1, ("set_fat_chain_length: %Lx to %lx clusters (%lx)\n", node->vnid, clusters, node->cluster));
|
DPRINTF(1, ("set_fat_chain_length: %Lx to %lx clusters (%lx)\n", node->vnid, clusters, node->cluster));
|
||||||
|
|
||||||
if (IS_FIXED_ROOT(node->cluster) || (!IS_DATA_CLUSTER(node->cluster) && (node->cluster != 0))) {
|
if (IS_FIXED_ROOT(node->cluster) || (!IS_DATA_CLUSTER(node->cluster) && (node->cluster != 0))) {
|
||||||
DPRINTF(0, ("set_fat_chain_length called on invalid cluster (%lx)\n", node->cluster));
|
DPRINTF(0, ("set_fat_chain_length called on invalid cluster (%lx)\n", node->cluster));
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
@ -570,7 +590,9 @@ status_t set_fat_chain_length(nspace *vol, vnode *node, uint32 clusters)
|
|||||||
return clear_fat_chain(vol, n);
|
return clear_fat_chain(vol, n);
|
||||||
}
|
}
|
||||||
|
|
||||||
void dump_fat_chain(nspace *vol, uint32 cluster)
|
|
||||||
|
void
|
||||||
|
dump_fat_chain(nspace *vol, uint32 cluster)
|
||||||
{
|
{
|
||||||
dprintf("fat chain: %lx", cluster);
|
dprintf("fat chain: %lx", cluster);
|
||||||
while (IS_DATA_CLUSTER(cluster)) {
|
while (IS_DATA_CLUSTER(cluster)) {
|
||||||
|
@ -1363,6 +1363,7 @@ dosfs_remove_vnode(fs_volume *_vol, fs_vnode *_node, bool reenter)
|
|||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// get rid of node or directory
|
// get rid of node or directory
|
||||||
static status_t
|
static status_t
|
||||||
do_unlink(fs_volume *_vol, fs_vnode *_dir, const char *name, bool is_file)
|
do_unlink(fs_volume *_vol, fs_vnode *_dir, const char *name, bool is_file)
|
||||||
@ -1475,6 +1476,7 @@ bi:
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
status_t
|
status_t
|
||||||
dosfs_unlink(fs_volume *vol, fs_vnode *dir, const char *name)
|
dosfs_unlink(fs_volume *vol, fs_vnode *dir, const char *name)
|
||||||
{
|
{
|
||||||
|
@ -49,8 +49,8 @@ csi_to_block(struct csi *csi)
|
|||||||
if (IS_FIXED_ROOT(csi->cluster))
|
if (IS_FIXED_ROOT(csi->cluster))
|
||||||
return csi->vol->root_start + csi->sector;
|
return csi->vol->root_start + csi->sector;
|
||||||
|
|
||||||
return csi->vol->data_start +
|
return csi->vol->data_start +
|
||||||
(off_t)(csi->cluster - 2)* csi->vol->sectors_per_cluster +
|
(off_t)(csi->cluster - 2)* csi->vol->sectors_per_cluster +
|
||||||
csi->sector;
|
csi->sector;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,9 +61,9 @@ init_csi(nspace *vol, uint32 cluster, uint32 sector, struct csi *csi)
|
|||||||
int ret;
|
int ret;
|
||||||
if ((ret = _validate_cs_(vol,cluster,sector)) != 0)
|
if ((ret = _validate_cs_(vol,cluster,sector)) != 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
csi->vol = vol; csi->cluster = cluster; csi->sector = sector;
|
csi->vol = vol; csi->cluster = cluster; csi->sector = sector;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -76,13 +76,13 @@ iter_csi(struct csi *csi, int sectors)
|
|||||||
|
|
||||||
if (sectors < 0)
|
if (sectors < 0)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
if (sectors == 0)
|
if (sectors == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (IS_FIXED_ROOT(csi->cluster)) {
|
if (IS_FIXED_ROOT(csi->cluster)) {
|
||||||
csi->sector += sectors;
|
csi->sector += sectors;
|
||||||
if (csi->sector < csi->vol->root_sectors)
|
if (csi->sector < csi->vol->root_sectors)
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
} else {
|
||||||
csi->sector += sectors;
|
csi->sector += sectors;
|
||||||
@ -103,7 +103,7 @@ iter_csi(struct csi *csi, int sectors)
|
|||||||
}
|
}
|
||||||
|
|
||||||
csi->sector = 0xffff;
|
csi->sector = 0xffff;
|
||||||
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -147,7 +147,7 @@ csi_mark_block_dirty(struct csi *csi, int32 tid)
|
|||||||
|
|
||||||
// TODO : block_cache doesn't implement this
|
// TODO : block_cache doesn't implement this
|
||||||
//block_cache_set_dirty(csi->vol->fBlockCache, csi_to_block(csi), true, tid);
|
//block_cache_set_dirty(csi->vol->fBlockCache, csi_to_block(csi), true, tid);
|
||||||
|
|
||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -162,7 +162,7 @@ csi_read_blocks(struct csi *csi, uint8 *buffer, ssize_t len)
|
|||||||
status_t err;
|
status_t err;
|
||||||
char *buf = buffer;
|
char *buf = buffer;
|
||||||
int32 i;
|
int32 i;
|
||||||
|
|
||||||
ASSERT(len >= csi->vol->bytes_per_sector);
|
ASSERT(len >= csi->vol->bytes_per_sector);
|
||||||
|
|
||||||
if (_validate_cs_(csi->vol, csi->cluster, csi->sector) != 0)
|
if (_validate_cs_(csi->vol, csi->cluster, csi->sector) != 0)
|
||||||
@ -247,13 +247,13 @@ csi_write_block(struct csi *csi, uint8 *buffer)
|
|||||||
off_t block;
|
off_t block;
|
||||||
int32 tid;
|
int32 tid;
|
||||||
char *blockData;
|
char *blockData;
|
||||||
|
|
||||||
block = csi_to_block(csi);
|
block = csi_to_block(csi);
|
||||||
|
|
||||||
ASSERT(_validate_cs_(csi->vol, csi->cluster, csi->sector) == 0);
|
ASSERT(_validate_cs_(csi->vol, csi->cluster, csi->sector) == 0);
|
||||||
if (_validate_cs_(csi->vol, csi->cluster, csi->sector) != 0)
|
if (_validate_cs_(csi->vol, csi->cluster, csi->sector) != 0)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
tid = cache_start_transaction(csi->vol->fBlockCache);
|
tid = cache_start_transaction(csi->vol->fBlockCache);
|
||||||
blockData = block_cache_get_writable_etc(csi->vol->fBlockCache, block, 0, 1, tid);
|
blockData = block_cache_get_writable_etc(csi->vol->fBlockCache, block, 0, 1, tid);
|
||||||
memcpy(blockData, buffer, csi->vol->bytes_per_sector);
|
memcpy(blockData, buffer, csi->vol->bytes_per_sector);
|
||||||
@ -293,7 +293,7 @@ diri_init(nspace *vol, uint32 cluster, uint32 index, struct diri *diri)
|
|||||||
&& iter_csi(&(diri->csi), diri->current_index
|
&& iter_csi(&(diri->csi), diri->current_index
|
||||||
/ (vol->bytes_per_sector / 0x20)) != 0)
|
/ (vol->bytes_per_sector / 0x20)) != 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
diri->tid = cache_start_transaction(diri->csi.vol->fBlockCache);
|
diri->tid = cache_start_transaction(diri->csi.vol->fBlockCache);
|
||||||
if (diri->tid < B_OK)
|
if (diri->tid < B_OK)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -322,7 +322,7 @@ diri_free(struct diri *diri)
|
|||||||
|
|
||||||
if (diri->current_block)
|
if (diri->current_block)
|
||||||
_diri_release_current_block_(diri);
|
_diri_release_current_block_(diri);
|
||||||
|
|
||||||
cache_end_transaction(diri->csi.vol->fBlockCache, diri->tid, NULL, NULL);
|
cache_end_transaction(diri->csi.vol->fBlockCache, diri->tid, NULL, NULL);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -333,7 +333,7 @@ uint8 *
|
|||||||
diri_current_entry(struct diri *diri)
|
diri_current_entry(struct diri *diri)
|
||||||
{
|
{
|
||||||
if (check_diri_magic(diri, "diri_current_entry")) return NULL;
|
if (check_diri_magic(diri, "diri_current_entry")) return NULL;
|
||||||
|
|
||||||
if (diri->current_block == NULL)
|
if (diri->current_block == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -346,7 +346,7 @@ uint8 *
|
|||||||
diri_next_entry(struct diri *diri)
|
diri_next_entry(struct diri *diri)
|
||||||
{
|
{
|
||||||
if (check_diri_magic(diri, "diri_next_entry")) return NULL;
|
if (check_diri_magic(diri, "diri_next_entry")) return NULL;
|
||||||
|
|
||||||
if (diri->current_block == NULL)
|
if (diri->current_block == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -358,7 +358,7 @@ diri_next_entry(struct diri *diri)
|
|||||||
if (diri->current_block == NULL)
|
if (diri->current_block == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return diri->current_block
|
return diri->current_block
|
||||||
+ (diri->current_index % (diri->csi.vol->bytes_per_sector / 0x20))*0x20;
|
+ (diri->current_index % (diri->csi.vol->bytes_per_sector / 0x20))*0x20;
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
Copyright 1999-2001, Be Incorporated. All Rights Reserved.
|
Copyright 1999-2001, Be Incorporated. All Rights Reserved.
|
||||||
This file may be used under the terms of the Be Sample Code License.
|
This file may be used under the terms of the Be Sample Code License.
|
||||||
|
|
||||||
extended: 2001-12-11 by Marcus Overhagen
|
extended: 2001-12-11 by Marcus Overhagen
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -19,7 +19,8 @@ static int32 tzoffset = -1; /* in minutes */
|
|||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
|
|
||||||
int _assert_(char *a, int b, char *c)
|
int
|
||||||
|
_assert_(char *a, int b, char *c)
|
||||||
{
|
{
|
||||||
dprintf("tripped assertion in %s/%d (%s)\n", a, b, c);
|
dprintf("tripped assertion in %s/%d (%s)\n", a, b, c);
|
||||||
kernel_debugger("tripped assertion");
|
kernel_debugger("tripped assertion");
|
||||||
@ -28,12 +29,15 @@ int _assert_(char *a, int b, char *c)
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void print_byte(uint8 c)
|
static void
|
||||||
|
print_byte(uint8 c)
|
||||||
{
|
{
|
||||||
dprintf("%c", ((c >= ' ') && (c <= '~')) ? c : '.');
|
dprintf("%c", ((c >= ' ') && (c <= '~')) ? c : '.');
|
||||||
}
|
}
|
||||||
|
|
||||||
void dump_bytes(uint8 *buffer, uint32 count)
|
|
||||||
|
void
|
||||||
|
dump_bytes(uint8 *buffer, uint32 count)
|
||||||
{
|
{
|
||||||
uint32 i, j, k;
|
uint32 i, j, k;
|
||||||
for (i=0;i<0x10;i++)
|
for (i=0;i<0x10;i++)
|
||||||
@ -52,16 +56,20 @@ void dump_bytes(uint8 *buffer, uint32 count)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void dump_directory(uint8 *buffer)
|
|
||||||
|
void
|
||||||
|
dump_directory(uint8 *buffer)
|
||||||
{
|
{
|
||||||
dump_bytes(buffer, 32);
|
dump_bytes(buffer, 32);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void get_tzoffset()
|
|
||||||
|
static void
|
||||||
|
get_tzoffset()
|
||||||
{
|
{
|
||||||
rtc_info info;
|
rtc_info info;
|
||||||
|
|
||||||
if (tzoffset != -1)
|
if (tzoffset != -1)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (get_rtc_info(&info) < 0) {
|
if (get_rtc_info(&info) < 0) {
|
||||||
@ -71,6 +79,7 @@ static void get_tzoffset()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// If divisible by 4, but not divisible by 100, but divisible by 400, it's a leap year
|
// If divisible by 4, but not divisible by 100, but divisible by 400, it's a leap year
|
||||||
// 1996 is leap, 1900 is not, 2000 is, 2100 is not
|
// 1996 is leap, 1900 is not, 2000 is, 2100 is not
|
||||||
#define IS_LEAP_YEAR(y) ((((y) % 4) == 0) && (((y) % 100) || ((((y)) % 400) == 0)))
|
#define IS_LEAP_YEAR(y) ((((y) % 4) == 0) && (((y) % 100) || ((((y)) % 400) == 0)))
|
||||||
@ -88,7 +97,8 @@ static int leaps(int yr, int mon)
|
|||||||
|
|
||||||
static int daze[] = { 0,0,31,59,90,120,151,181,212,243,273,304,334,0,0,0 };
|
static int daze[] = { 0,0,31,59,90,120,151,181,212,243,273,304,334,0,0,0 };
|
||||||
|
|
||||||
time_t dos2time_t(uint32 t)
|
time_t
|
||||||
|
dos2time_t(uint32 t)
|
||||||
{
|
{
|
||||||
time_t days;
|
time_t days;
|
||||||
|
|
||||||
@ -103,7 +113,9 @@ time_t dos2time_t(uint32 t)
|
|||||||
return (((days * 24) + ((t>>11)&31)) * 60 + ((t>>5)&63) + tzoffset) * 60 + 2*(t&31);
|
return (((days * 24) + ((t>>11)&31)) * 60 + ((t>>5)&63) + tzoffset) * 60 + 2*(t&31);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32 time_t2dos(time_t s)
|
|
||||||
|
uint32
|
||||||
|
time_t2dos(time_t s)
|
||||||
{
|
{
|
||||||
uint32 t, d, y;
|
uint32 t, d, y;
|
||||||
int days;
|
int days;
|
||||||
@ -141,7 +153,9 @@ bi:
|
|||||||
return t + (d << 16) + (y << 25);
|
return t + (d << 16) + (y << 25);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8 hash_msdos_name(const char *name)
|
|
||||||
|
uint8
|
||||||
|
hash_msdos_name(const char *name)
|
||||||
{
|
{
|
||||||
const uint8 *p = (const uint8 *)name;
|
const uint8 *p = (const uint8 *)name;
|
||||||
int i;
|
int i;
|
||||||
|
@ -16,7 +16,7 @@ There are three ways to encode a vnode id:
|
|||||||
directory it appears in. This is used for files with data.
|
directory it appears in. This is used for files with data.
|
||||||
2. Combine the starting cluster of the directory the entry appears in with the
|
2. Combine the starting cluster of the directory the entry appears in with the
|
||||||
index of the entry in the directory. This is used for 0-byte files.
|
index of the entry in the directory. This is used for 0-byte files.
|
||||||
3. A unique number that doesn't match any possible values from encodings 1 or
|
3. A unique number that doesn't match any possible values from encodings 1 or
|
||||||
2.
|
2.
|
||||||
|
|
||||||
With the first encoding, the vnode id is invalidated (i.e. no longer describes
|
With the first encoding, the vnode id is invalidated (i.e. no longer describes
|
||||||
@ -73,7 +73,7 @@ void dump_vcache(nspace *vol)
|
|||||||
uint32 i;
|
uint32 i;
|
||||||
struct vcache_entry *c;
|
struct vcache_entry *c;
|
||||||
dprintf("vnid cache size %lx, cur vnid = %Lx\n"
|
dprintf("vnid cache size %lx, cur vnid = %Lx\n"
|
||||||
"vnid loc\n",
|
"vnid loc\n",
|
||||||
vol->vcache.cache_size, vol->vcache.cur_vnid);
|
vol->vcache.cache_size, vol->vcache.cur_vnid);
|
||||||
for (i=0;i<vol->vcache.cache_size;i++)
|
for (i=0;i<vol->vcache.cache_size;i++)
|
||||||
for (c = vol->vcache.by_vnid[i];c;c=c->next_vnid)
|
for (c = vol->vcache.by_vnid[i];c;c=c->next_vnid)
|
||||||
@ -118,7 +118,9 @@ status_t init_vcache(nspace *vol)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t uninit_vcache(nspace *vol)
|
|
||||||
|
status_t
|
||||||
|
uninit_vcache(nspace *vol)
|
||||||
{
|
{
|
||||||
uint32 i, count = 0;
|
uint32 i, count = 0;
|
||||||
struct vcache_entry *c, *n;
|
struct vcache_entry *c, *n;
|
||||||
@ -147,7 +149,9 @@ status_t uninit_vcache(nspace *vol)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
ino_t generate_unique_vnid(nspace *vol)
|
|
||||||
|
ino_t
|
||||||
|
generate_unique_vnid(nspace *vol)
|
||||||
{
|
{
|
||||||
DPRINTF(0, ("generate_unique_vnid\n"));
|
DPRINTF(0, ("generate_unique_vnid\n"));
|
||||||
/* only one thread per volume will be in here at any given time anyway
|
/* only one thread per volume will be in here at any given time anyway
|
||||||
@ -155,7 +159,9 @@ ino_t generate_unique_vnid(nspace *vol)
|
|||||||
return vol->vcache.cur_vnid++;
|
return vol->vcache.cur_vnid++;
|
||||||
}
|
}
|
||||||
|
|
||||||
static status_t _add_to_vcache_(nspace *vol, ino_t vnid, ino_t loc)
|
|
||||||
|
static status_t
|
||||||
|
_add_to_vcache_(nspace *vol, ino_t vnid, ino_t loc)
|
||||||
{
|
{
|
||||||
int hash1 = hash(vnid), hash2 = hash(loc);
|
int hash1 = hash(vnid), hash2 = hash(loc);
|
||||||
struct vcache_entry *e, *c, *p;
|
struct vcache_entry *e, *c, *p;
|
||||||
@ -205,7 +211,9 @@ static status_t _add_to_vcache_(nspace *vol, ino_t vnid, ino_t loc)
|
|||||||
return B_OK;
|
return B_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static status_t _remove_from_vcache_(nspace *vol, ino_t vnid)
|
|
||||||
|
static status_t
|
||||||
|
_remove_from_vcache_(nspace *vol, ino_t vnid)
|
||||||
{
|
{
|
||||||
int hash1 = hash(vnid), hash2;
|
int hash1 = hash(vnid), hash2;
|
||||||
struct vcache_entry *c, *p, *e;
|
struct vcache_entry *c, *p, *e;
|
||||||
@ -252,7 +260,9 @@ static status_t _remove_from_vcache_(nspace *vol, ino_t vnid)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct vcache_entry *_find_vnid_in_vcache_(nspace *vol, ino_t vnid)
|
|
||||||
|
static struct vcache_entry *
|
||||||
|
_find_vnid_in_vcache_(nspace *vol, ino_t vnid)
|
||||||
{
|
{
|
||||||
int hash1 = hash(vnid);
|
int hash1 = hash(vnid);
|
||||||
struct vcache_entry *c;
|
struct vcache_entry *c;
|
||||||
@ -268,7 +278,9 @@ static struct vcache_entry *_find_vnid_in_vcache_(nspace *vol, ino_t vnid)
|
|||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct vcache_entry *_find_loc_in_vcache_(nspace *vol, ino_t loc)
|
|
||||||
|
static struct vcache_entry *
|
||||||
|
_find_loc_in_vcache_(nspace *vol, ino_t loc)
|
||||||
{
|
{
|
||||||
int hash2 = hash(loc);
|
int hash2 = hash(loc);
|
||||||
struct vcache_entry *c;
|
struct vcache_entry *c;
|
||||||
@ -284,7 +296,9 @@ static struct vcache_entry *_find_loc_in_vcache_(nspace *vol, ino_t loc)
|
|||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t add_to_vcache(nspace *vol, ino_t vnid, ino_t loc)
|
|
||||||
|
status_t
|
||||||
|
add_to_vcache(nspace *vol, ino_t vnid, ino_t loc)
|
||||||
{
|
{
|
||||||
status_t result;
|
status_t result;
|
||||||
|
|
||||||
@ -296,8 +310,10 @@ status_t add_to_vcache(nspace *vol, ino_t vnid, ino_t loc)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* XXX: do this in a smarter fashion */
|
/* XXX: do this in a smarter fashion */
|
||||||
static status_t _update_loc_in_vcache_(nspace *vol, ino_t vnid, ino_t loc)
|
static status_t
|
||||||
|
_update_loc_in_vcache_(nspace *vol, ino_t vnid, ino_t loc)
|
||||||
{
|
{
|
||||||
status_t result;
|
status_t result;
|
||||||
|
|
||||||
@ -308,7 +324,9 @@ static status_t _update_loc_in_vcache_(nspace *vol, ino_t vnid, ino_t loc)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t remove_from_vcache(nspace *vol, ino_t vnid)
|
|
||||||
|
status_t
|
||||||
|
remove_from_vcache(nspace *vol, ino_t vnid)
|
||||||
{
|
{
|
||||||
status_t result;
|
status_t result;
|
||||||
|
|
||||||
@ -320,7 +338,9 @@ status_t remove_from_vcache(nspace *vol, ino_t vnid)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t vcache_vnid_to_loc(nspace *vol, ino_t vnid, ino_t *loc)
|
|
||||||
|
status_t
|
||||||
|
vcache_vnid_to_loc(nspace *vol, ino_t vnid, ino_t *loc)
|
||||||
{
|
{
|
||||||
struct vcache_entry *e;
|
struct vcache_entry *e;
|
||||||
|
|
||||||
@ -335,7 +355,9 @@ status_t vcache_vnid_to_loc(nspace *vol, ino_t vnid, ino_t *loc)
|
|||||||
return (e) ? B_OK : ENOENT;
|
return (e) ? B_OK : ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t vcache_loc_to_vnid(nspace *vol, ino_t loc, ino_t *vnid)
|
|
||||||
|
status_t
|
||||||
|
vcache_loc_to_vnid(nspace *vol, ino_t loc, ino_t *vnid)
|
||||||
{
|
{
|
||||||
struct vcache_entry *e;
|
struct vcache_entry *e;
|
||||||
|
|
||||||
@ -350,7 +372,9 @@ status_t vcache_loc_to_vnid(nspace *vol, ino_t loc, ino_t *vnid)
|
|||||||
return (e) ? B_OK : ENOENT;
|
return (e) ? B_OK : ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
status_t vcache_set_entry(nspace *vol, ino_t vnid, ino_t loc)
|
|
||||||
|
status_t
|
||||||
|
vcache_set_entry(nspace *vol, ino_t vnid, ino_t loc)
|
||||||
{
|
{
|
||||||
struct vcache_entry *e;
|
struct vcache_entry *e;
|
||||||
status_t result = B_OK;
|
status_t result = B_OK;
|
||||||
@ -385,7 +409,8 @@ status_t vcache_set_entry(nspace *vol, ino_t vnid, ino_t loc)
|
|||||||
|
|
||||||
#if DEBUG
|
#if DEBUG
|
||||||
|
|
||||||
int debug_dfvnid(int argc, char **argv)
|
int
|
||||||
|
debug_dfvnid(int argc, char **argv)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
nspace *vol;
|
nspace *vol;
|
||||||
|
Loading…
Reference in New Issue
Block a user