/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License (the "License"). * You may not use this file except in compliance with the License. * * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE * or http://www.opensolaris.org/os/licensing. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at usr/src/OPENSOLARIS.LICENSE. * If applicable, add the following below this CDDL HEADER, with the * fields enclosed by brackets "[]" replaced with your own identifying * information: Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END */ /* * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. */ #include #include #include #include #include #include "bblk_einfo.h" #include "boot_utils.h" boolean_t boot_debug = B_FALSE; boolean_t nowrite = B_FALSE; void boot_gdebug(const char *funcname, char *format, ...) { va_list ap; if (boot_debug == B_FALSE) return; (void) fprintf(stdout, "%s(): ", funcname); va_start(ap, format); /* LINTED: E_SEC_PRINTF_VAR_FMT */ (void) vfprintf(stdout, format, ap); va_end(ap); } /* * Common functions to write out and read in block-sized data to a file * descriptor. */ int write_out(int fd, void *buffer, size_t size, off_t off) { int ret; char *buf = buffer; if (size % SECTOR_SIZE != 0) BOOT_DEBUG("Expected block-sized data, got: %d\n", size); /* Dry run. */ if (nowrite) return (BC_SUCCESS); for (;;) { again: ret = pwrite(fd, buf, size, off); if (ret == -1) { if (errno == EAGAIN) goto again; else return (BC_ERROR); } if (ret < size) { size -= ret; off += ret; buf += ret; } else { break; } } return (BC_SUCCESS); } int read_in(int fd, void *buffer, size_t size, off_t off) { int ret; char *buf = buffer; if (size % SECTOR_SIZE != 0) BOOT_DEBUG("Expected block-sized data, got: %d\n", size); for (;;) { again: ret = pread(fd, buf, size, off); if (ret == -1) { if (errno == EAGAIN) goto again; else return (BC_ERROR); } if (ret < size) { size -= ret; off += ret; buf += ret; } else { break; } } return (BC_SUCCESS); }