summaryrefslogtreecommitdiffstats
path: root/qemu/roms/openhackware/src/libfs/raw.c
diff options
context:
space:
mode:
authorRajithaY <rajithax.yerrumsetty@intel.com>2017-04-25 03:31:15 -0700
committerRajitha Yerrumchetty <rajithax.yerrumsetty@intel.com>2017-05-22 06:48:08 +0000
commitbb756eebdac6fd24e8919e2c43f7d2c8c4091f59 (patch)
treeca11e03542edf2d8f631efeca5e1626d211107e3 /qemu/roms/openhackware/src/libfs/raw.c
parenta14b48d18a9ed03ec191cf16b162206998a895ce (diff)
Adding qemu as a submodule of KVMFORNFV
This Patch includes the changes to add qemu as a submodule to kvmfornfv repo and make use of the updated latest qemu for the execution of all testcase Change-Id: I1280af507a857675c7f81d30c95255635667bdd7 Signed-off-by:RajithaY<rajithax.yerrumsetty@intel.com>
Diffstat (limited to 'qemu/roms/openhackware/src/libfs/raw.c')
-rw-r--r--qemu/roms/openhackware/src/libfs/raw.c178
1 files changed, 0 insertions, 178 deletions
diff --git a/qemu/roms/openhackware/src/libfs/raw.c b/qemu/roms/openhackware/src/libfs/raw.c
deleted file mode 100644
index 9ecd23ad1..000000000
--- a/qemu/roms/openhackware/src/libfs/raw.c
+++ /dev/null
@@ -1,178 +0,0 @@
-/*
- * <raw.c>
- *
- * Open Hack'Ware BIOS raw file system management
- *
- * Copyright (c) 2004-2005 Jocelyn Mayer
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License V2
- * as published by the Free Software Foundation
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
- */
-
-#include <stdlib.h>
-#include <stdio.h>
-#include "bios.h"
-#include "../libpart/libpart.h"
-#include "libfs.h"
-
-/* Raw filesystem (ie no filesystem) */
-static inode_t *fs_raw_get_inode (inode_t *parent, const unsigned char *name)
-{
- inode_t *new;
- fs_t *fs;
- int flags;
-
- if (parent != NULL) {
- return NULL;
- }
- /* Open root inode */
- flags = INODE_TYPE_DIR;
- fs = NULL;
- new = malloc(sizeof(inode_t));
- memset(new, 0, sizeof(inode_t));
- new->flags = flags;
- new->name = strdup(name);
-
- return new;
-}
-
-static void fs_raw_put_inode (inode_t *inode)
-{
- free(inode);
-}
-
-static uint32_t fs_raw_map_bloc (unused inode_t *inode, uint32_t bloc)
-{
- if (inode != NULL
- /* XXX: can't figure out why I did this... */
- /* && inode == inode->fs->bootfile*/
- )
- bloc += inode->blocs[0].bloc;
-
- return bloc;
-}
-
-static inode_t *fs_raw_get_special_inode (fs_t *fs, int type)
-{
- const unsigned char *name;
- inode_t *new, *parent, **inp;
- int flags;
-
- new = NULL;
- name = NULL;
- parent = NULL;
- inp = NULL;
- flags = 0;
- switch (type) {
- case FILE_ROOT:
- if (fs->root != NULL) {
- new = fs->root;
- } else {
- flags = INODE_TYPE_DIR;
- parent = NULL;
- name = NULL;
- inp = &fs->root;
- }
- break;
- case FILE_BOOT:
- if (fs->bootfile != NULL) {
- dprintf("bootfile already exists\n");
- new = fs->bootfile;
- } else {
- new = part_private_get(fs_part(fs));
- if (fs->bootdir == NULL) {
- dprintf("Get boot directory\n");
- fs->bootdir = fs_raw_get_special_inode(fs, FILE_BOOTDIR);
- }
- parent = fs->bootdir;
- if (new != NULL) {
- dprintf("Fix bootfile\n");
- new->parent = parent;
- new->fs = fs;
- } else {
- dprintf("New bootfile\n");
- flags = INODE_TYPE_FILE | INODE_FLAG_EXEC | INODE_FLAG_BOOT;
- name = "ofwboot";
- inp = &fs->bootfile;
- }
- }
- break;
- case FILE_BOOTDIR:
- if (fs->bootdir != NULL) {
- new = fs->bootdir;
- } else {
- flags = INODE_TYPE_DIR;
- parent = fs->root;
- name = "boot";
- inp = &fs->bootdir;
- }
- break;
- default:
- return NULL;
- }
- if (new == NULL) {
- new = malloc(sizeof(inode_t));
- memset(new, 0, sizeof(inode_t));
- new->flags = flags;
- new->parent = parent;
- if (name != NULL)
- new->name = strdup(name);
- new->fs = fs;
- *inp = new;
- }
-
- return new;
-}
-
-static fs_ops_t fs_ops_raw = {
- &fs_raw_get_inode,
- &fs_raw_put_inode,
- &fs_raw_map_bloc,
- &fs_raw_get_special_inode,
-};
-
-int fs_raw_set_bootfile (part_t *part,
- uint32_t start_bloc, uint32_t start_offset,
- uint32_t size_bloc, uint32_t size_offset)
-{
- inode_t *new;
-
- new = malloc(sizeof(inode_t));
- if (new == NULL)
- return -1;
- DPRINTF("%s: pos %d %d size %d %d\n", __func__, start_bloc, start_offset,
- size_bloc, size_offset);
- memset(new, 0, sizeof(inode_t));
- new->flags = INODE_TYPE_FILE | INODE_FLAG_EXEC | INODE_FLAG_BOOT;
- new->name = "ofwboot";
- new->blocs[0].bloc = start_bloc;
- new->blocs[0].offset = start_offset;
- new->size.bloc = size_bloc;
- new->size.offset = size_offset;
- new->nb_blocs = size_bloc;
- part_private_set(part, new);
-
- return 0;
-}
-
-int fs_raw_probe (part_t *part, uint32_t *size,
- fs_ops_t **fs_ops, unsigned char **name,
- unused void **private)
-{
- DPRINTF("%s: %p map_bloc %p\n", __func__, &fs_ops_raw, &fs_raw_map_bloc);
- *fs_ops = &fs_ops_raw;
- *name = "Raw FS";
- *size = part_size(part);
-
- return FS_TYPE_RAW;
-}