update Intel copyright years to 2014
[dpdk.git] / lib / librte_eal / linuxapp / eal / include / eal_filesystem.h
1 /*-
2  *   BSD LICENSE
3  * 
4  *   Copyright(c) 2010-2014 Intel Corporation. All rights reserved.
5  *   All rights reserved.
6  * 
7  *   Redistribution and use in source and binary forms, with or without
8  *   modification, are permitted provided that the following conditions
9  *   are met:
10  * 
11  *     * Redistributions of source code must retain the above copyright
12  *       notice, this list of conditions and the following disclaimer.
13  *     * Redistributions in binary form must reproduce the above copyright
14  *       notice, this list of conditions and the following disclaimer in
15  *       the documentation and/or other materials provided with the
16  *       distribution.
17  *     * Neither the name of Intel Corporation nor the names of its
18  *       contributors may be used to endorse or promote products derived
19  *       from this software without specific prior written permission.
20  * 
21  *   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  *   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  *   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24  *   A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25  *   OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26  *   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27  *   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28  *   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29  *   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30  *   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31  *   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  */
33
34 /**
35  * @file
36  * Stores functions and path defines for files and directories
37  * on the filesystem for Linux, that are used by the Linux EAL.
38  */
39
40 #ifndef _EAL_LINUXAPP_FILESYSTEM_H
41 #define _EAL_LINUXAPP_FILESYSTEM_H
42
43 /** Path of rte config file. */
44 #define RUNTIME_CONFIG_FMT "%s/.%s_config"
45
46 #include <stdint.h>
47 #include <limits.h>
48 #include <unistd.h>
49 #include <rte_string_fns.h>
50 #include "eal_internal_cfg.h"
51
52 static const char *default_config_dir = "/var/run";
53
54 static inline const char *
55 eal_runtime_config_path(void)
56 {
57         static char buffer[PATH_MAX]; /* static so auto-zeroed */
58         const char *directory = default_config_dir;
59         const char *home_dir = getenv("HOME");
60
61         if (getuid() != 0 && home_dir != NULL)
62                 directory = home_dir;
63         rte_snprintf(buffer, sizeof(buffer) - 1, RUNTIME_CONFIG_FMT, directory,
64                         internal_config.hugefile_prefix);
65         return buffer;
66 }
67
68 /** Path of hugepage info file. */
69 #define HUGEPAGE_INFO_FMT "%s/.%s_hugepage_info"
70
71 static inline const char *
72 eal_hugepage_info_path(void)
73 {
74         static char buffer[PATH_MAX]; /* static so auto-zeroed */
75         const char *directory = default_config_dir;
76         const char *home_dir = getenv("HOME");
77
78         if (getuid() != 0 && home_dir != NULL)
79                 directory = home_dir;
80         rte_snprintf(buffer, sizeof(buffer) - 1, HUGEPAGE_INFO_FMT, directory,
81                         internal_config.hugefile_prefix);
82         return buffer;
83 }
84
85 /** String format for hugepage map files. */
86 #define HUGEFILE_FMT "%s/%smap_%d"
87
88 static inline const char *
89 eal_get_hugefile_path(char *buffer, size_t buflen, const char *hugedir, int f_id)
90 {
91         rte_snprintf(buffer, buflen, HUGEFILE_FMT, hugedir,
92                         internal_config.hugefile_prefix, f_id);
93         buffer[buflen - 1] = '\0';
94         return buffer;
95 }
96
97 /** define the default filename prefix for the %s values above */
98 #define HUGEFILE_PREFIX_DEFAULT "rte"
99
100 /** Function to read a single numeric value from a file on the filesystem.
101  * Used to read information from files on /sys */
102 int eal_parse_sysfs_value(const char *filename, unsigned long *val);
103
104 #endif /* _EAL_LINUXAPP_FILESYSTEM_H */