/* IBM_PROLOG_BEGIN_TAG */ /* This is an automatically generated prolog. */ /* */ /* $Source: fpart/src/cmd_hexdump.c $ */ /* */ /* OpenPOWER FFS Project */ /* */ /* Contributors Listed Below - COPYRIGHT 2014,2015 */ /* [+] International Business Machines Corp. */ /* */ /* */ /* Licensed under the Apache License, Version 2.0 (the "License"); */ /* you may not use this file except in compliance with the License. */ /* You may obtain a copy of the License at */ /* */ /* http://www.apache.org/licenses/LICENSE-2.0 */ /* */ /* Unless required by applicable law or agreed to in writing, software */ /* distributed under the License is distributed on an "AS IS" BASIS, */ /* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or */ /* implied. See the License for the specific language governing */ /* permissions and limitations under the License. */ /* */ /* IBM_PROLOG_END_TAG */ /* * File: hexdump.c * Author: Shaun Wetzstein * Descr: --hexdump implementation * Date: 01/30/2013 */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "main.h" int command_hexdump(args_t * args) { assert(args != NULL); char name[strlen(args->name) + 2]; strcpy(name, args->name); if (strrchr(name, '$') == NULL) strcat(name, "$"); char full_name[page_size]; regex_t rx; off_t __poffset; ffs_t * __ffs; list_t list; list_init(&list); list_iter_t it; ffs_entry_node_t * node; /* ========================= */ int hexdump_entry(ffs_entry_t * entry) { if (__ffs_entry_name(__ffs, entry, full_name, sizeof full_name) < 0) return -1; if (regexec(&rx, full_name, 0, NULL, 0) == REG_NOMATCH) return 0; if (entry->flags & FFS_FLAGS_PROTECTED && args->force != f_FORCE) { printf("%llx: %s: protected, skipping hexdump\n", __poffset, full_name); return 0; } list_iter_init(&it, &list, LI_FLAG_FWD); list_for_each(&it, node, node) { if (node->entry.base == entry->base && node->entry.size == entry->size) return 0; } node = (ffs_entry_node_t *)malloc(sizeof(*node)); assert(node != NULL); memcpy(&node->entry, entry, sizeof(node->entry)); list_add_tail(&list, &node->node); if (__ffs_entry_hexdump(__ffs, full_name, stdout) < 0) return -1; if (args->verbose == f_VERBOSE) printf("%llx: %s: partition actual '%x'\n", __poffset, full_name, entry->actual); return 0; } int hexdump(args_t * args, off_t poffset) { __poffset = poffset; const char * target = args->target; int debug = args->debug; RAII(FILE*, file, fopen_generic(target, "r", debug), fclose); if (file == NULL) return -1; RAII(ffs_t*, ffs, __ffs_fopen(file, poffset), __ffs_fclose); if (ffs == NULL) return -1; __ffs = ffs; int rc = __ffs_iterate_entries(ffs, hexdump_entry); if (rc == 1) rc = -1; return rc; } /* ========================= */ if (regcomp(&rx, name, REG_ICASE | REG_NOSUB) != 0) { ERRNO(errno); return -1; } int rc = command(args, hexdump); regfree(&rx); while (!list_empty(&list)) free(container_of(list_remove_head(&list), ffs_entry_node_t, node)); return rc; }