blob: 9bdaccc7c8a477195224e26f7da7e85eed9ee293 [file] [log] [blame]
khenaidoo59ce9dd2019-11-11 13:05:32 -05001// Copyright 2018 The Prometheus Authors
2// Licensed under the Apache License, Version 2.0 (the "License");
3// you may not use this file except in compliance with the License.
4// You may obtain a copy of the License at
5//
6// http://www.apache.org/licenses/LICENSE-2.0
7//
8// Unless required by applicable law or agreed to in writing, software
9// distributed under the License is distributed on an "AS IS" BASIS,
10// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11// See the License for the specific language governing permissions and
12// limitations under the License.
13
14package procfs
15
16import (
17 "github.com/prometheus/procfs/internal/fs"
18)
19
20// FS represents the pseudo-filesystem sys, which provides an interface to
21// kernel data structures.
22type FS struct {
Abhay Kumar40252eb2025-10-13 13:25:53 +000023 proc fs.FS
24 isReal bool
khenaidoo59ce9dd2019-11-11 13:05:32 -050025}
26
Abhay Kumar40252eb2025-10-13 13:25:53 +000027const (
28 // DefaultMountPoint is the common mount point of the proc filesystem.
29 DefaultMountPoint = fs.DefaultProcMountPoint
30
31 // SectorSize represents the size of a sector in bytes.
32 // It is specific to Linux block I/O operations.
33 SectorSize = 512
34)
khenaidoo59ce9dd2019-11-11 13:05:32 -050035
36// NewDefaultFS returns a new proc FS mounted under the default proc mountPoint.
37// It will error if the mount point directory can't be read or is a file.
38func NewDefaultFS() (FS, error) {
39 return NewFS(DefaultMountPoint)
40}
41
42// NewFS returns a new proc FS mounted under the given proc mountPoint. It will error
43// if the mount point directory can't be read or is a file.
44func NewFS(mountPoint string) (FS, error) {
45 fs, err := fs.NewFS(mountPoint)
46 if err != nil {
47 return FS{}, err
48 }
Abhay Kumar40252eb2025-10-13 13:25:53 +000049
50 isReal, err := isRealProc(mountPoint)
51 if err != nil {
52 return FS{}, err
53 }
54
55 return FS{fs, isReal}, nil
khenaidoo59ce9dd2019-11-11 13:05:32 -050056}