VirtualBox

source: vbox/trunk/include/iprt/linux/sysfs.h@ 16101

Last change on this file since 16101 was 15644, checked in by vboxsync, 16 years ago

IPRT: sysfs review, fixes and cleanup.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.9 KB
Line 
1/* $Id: sysfs.h 15644 2008-12-18 11:16:58Z vboxsync $ */
2/** @file
3 * IPRT - Linux sysfs access.
4 */
5
6/*
7 * Copyright (C) 2008 Sun Microsystems, Inc.
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 *
26 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
27 * Clara, CA 95054 USA or visit http://www.sun.com if you need
28 * additional information or have any questions.
29 */
30
31#ifndef ___iprt_linux_sysfs_h
32#define ___iprt_linux_sysfs_h
33
34#include <iprt/cdefs.h>
35#include <iprt/types.h>
36#include <iprt/stdarg.h>
37
38
39__BEGIN_DECLS
40
41/** @defgroup grp_rt_mp RTLinuxSysfs - Linux sysfs
42 * @ingroup grp_rt
43 * @{
44 */
45
46/**
47 * Checks if a sysfs file (or directory, device, symlink, whatever) exists.
48 *
49 * @returns true / false, errno is preserved.
50 * @param pszFormat The name format, either absolute or relative to "/sys/".
51 * @param va The format args.
52 */
53RTDECL(bool) RTLinuxSysFsExistsV(const char *pszFormat, va_list va);
54
55/**
56 * Checks if a sysfs file (or directory, device, symlink, whatever) exists.
57 *
58 * @returns true / false, errno is preserved.
59 * @param pszFormat The name format, either absolute or relative to "/sys/".
60 * @param ... The format args.
61 */
62RTDECL(bool) RTLinuxSysFsExists(const char *pszFormat, ...);
63
64/**
65 * Opens a sysfs file.
66 *
67 * @returns The file descriptor. -1 and errno on failure.
68 * @param pszFormat The name format, either absolute or relative to "/sys/".
69 * @param va The format args.
70 */
71RTDECL(int) RTLinuxSysFsOpenV(const char *pszFormat, va_list va);
72
73/**
74 * Opens a sysfs file.
75 *
76 * @returns The file descriptor. -1 and errno on failure.
77 * @param pszFormat The name format, either absolute or relative to "/sys/".
78 * @param ... The format args.
79 */
80RTDECL(int) RTLinuxSysFsOpen(const char *pszFormat, ...);
81
82/**
83 * Closes a file opened with RTLinuxSysFsOpen or RTLinuxSysFsOpenV.
84 *
85 * @param fd File descriptor returned by RTLinuxSysFsOpen or
86 * RTLinuxSysFsOpenV.
87 */
88RTDECL(void) RTLinuxSysFsClose(int fd);
89
90/**
91 * Reads a string from a file opened with RTLinuxSysFsOpen or RTLinuxSysFsOpenV.
92 *
93 * @returns The number of bytes read. -1 and errno on failure.
94 * @param fd The file descriptor returned by RTLinuxSysFsOpen or RTLinuxSysFsOpenV.
95 * @param pszBuf Where to store the string.
96 * @param cchBuf The size of the buffer. Must be at least 2 bytes.
97 */
98RTDECL(ssize_t) RTLinuxSysFsReadStr(int fd, char *pszBuf, size_t cchBuf);
99
100/**
101 * Reads a number from a sysfs file.
102 *
103 * @returns 64-bit signed value on success, -1 and errno on failure.
104 * @param uBase The number base, 0 for autodetect.
105 * @param pszFormat The filename format, either absolute or relative to "/sys/".
106 * @param va Format args.
107 */
108RTDECL(int64_t) RTLinuxSysFsReadIntFileV(unsigned uBase, const char *pszFormat, va_list va);
109
110/**
111 * Reads a number from a sysfs file.
112 *
113 * @returns 64-bit signed value on success, -1 and errno on failure.
114 * @param uBase The number base, 0 for autodetect.
115 * @param pszFormat The filename format, either absolute or relative to "/sys/".
116 * @param ... Format args.
117 */
118RTDECL(int64_t) RTLinuxSysFsReadIntFile(unsigned uBase, const char *pszFormat, ...);
119
120/**
121 * Reads a string from a sysfs file. If the file contains a newline, we only
122 * return the text up until there.
123 *
124 * @returns number of characters read on success, -1 and errno on failure.
125 * @param pszBuf Where to store the path element. Must be at least two
126 * characters, but a longer buffer would be advisable.
127 * @param cchBuf The size of the buffer pointed to by @a pszBuf.
128 * @param pszFormat The filename format, either absolute or relative to "/sys/".
129 * @param va Format args.
130 */
131RTDECL(ssize_t) RTLinuxSysFsReadStrFileV(char *pszBuf, size_t cchBuf, const char *pszFormat, va_list va);
132
133/**
134 * Reads a string from a sysfs file. If the file contains a newline, we only
135 * return the text up until there.
136 *
137 * @returns number of characters read on success, -1 and errno on failure.
138 * @param pszBuf Where to store the path element. Must be at least two
139 * characters, but a longer buffer would be advisable.
140 * @param cchBuf The size of the buffer pointed to by @a pszBuf.
141 * @param pszFormat The filename format, either absolute or relative to "/sys/".
142 * @param ... Format args.
143 */
144RTDECL(ssize_t) RTLinuxSysFsReadStrFile(char *pszBuf, size_t cchBuf, const char *pszFormat, ...);
145
146/**
147 * Reads the last element of the path of the file pointed to by the symbolic
148 * link specified.
149 *
150 * This is needed at least to get the name of the driver associated with a
151 * device, where pszFormat should be the "driver" link in the devices sysfs
152 * directory.
153 *
154 * @returns The number of characters written on success, -1 and errno on failure.
155 * @param pszBuf Where to store the path element. Must be at least two
156 * characters, but a longer buffer would be advisable.
157 * @param cchBuf The size of the buffer pointed to by @a pszBuf.
158 * @param pszFormat The filename format, either absolute or relative to "/sys/".
159 * @param va Format args.
160 */
161RTDECL(ssize_t) RTLinuxSysFsGetLinkDestV(char *pszBuf, size_t cchBuf, const char *pszFormat, va_list va);
162
163/**
164 * Reads the last element of the path of the file pointed to by the symbolic
165 * link specified.
166 *
167 * This is needed at least to get the name of the driver associated with a
168 * device, where pszFormat should be the "driver" link in the devices sysfs
169 * directory.
170 *
171 * @returns The number of characters written on success, -1 and errno on failure.
172 * @param pszBuf Where to store the path element. Must be at least two
173 * characters, but a longer buffer would be advisable.
174 * @param cchBuf The size of the buffer pointed to by @a pszBuf.
175 * @param pszFormat The filename format, either absolute or relative to "/sys/".
176 * @param ... Format args.
177 */
178RTDECL(ssize_t) RTLinuxSysFsGetLinkDest(char *pszBuf, size_t cchBuf, const char *pszFormat, ...);
179
180/** @} */
181
182__END_DECLS
183
184#endif
185
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette