libexplain
1.4.D001
|
00001 /* 00002 * libexplain - Explain errno values returned by libc functions 00003 * Copyright (C) 2009-2011, 2013 Peter Miller 00004 * Written by Peter Miller <pmiller@opensource.org.au> 00005 * 00006 * This program is free software; you can redistribute it and/or modify it 00007 * under the terms of the GNU Lesser General Public License as published by 00008 * the Free Software Foundation; either version 3 of the License, or (at your 00009 * option) any later version. 00010 * 00011 * This program is distributed in the hope that it will be useful, but WITHOUT 00012 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00013 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public 00014 * License for more details. 00015 * 00016 * You should have received a copy of the GNU Lesser General Public License 00017 * along with this program. If not, see <http://www.gnu.org/licenses/>. 00018 */ 00019 00020 #include <libexplain/ac/sys/ioctl.h> 00021 #include <libexplain/buffer/pointer.h> 00022 #include <libexplain/iocontrol.h> 00023 #include <libexplain/is_efault.h> 00024 #include <libexplain/string_buffer.h> 00025 00026 00027 void 00028 explain_iocontrol_print_data(const explain_iocontrol_t *p, 00029 explain_string_buffer_t *sb, int errnum, int fildes, int request, 00030 const void *data) 00031 { 00032 /* 00033 * It is tempting to check that data is a valid pointer, using 00034 * !explain_is_efault_pointer(data), at this point. This is 00035 * undesiable in the general case because there are some ioctl 00036 * requests that actually pass an integer value as data, rather than 00037 * a pointer value. Yes, it stinks; no, it can't be changed. 00038 */ 00039 if (p && p->print_data) 00040 p->print_data(p, sb, errnum, fildes, request, data); 00041 else 00042 explain_buffer_pointer(sb, data); 00043 } 00044 00045 00046 /* vim: set ts=8 sw=4 et : */