blob: 6a4b898b8c0e3bc0006bec54ad692ef1f9a4fe35 [file] [log] [blame]
Matt Spinler4e97ebe2017-02-28 10:02:16 -06001/**
2 * Copyright © 2017 IBM Corporation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#include <stdexcept>
17#include <unistd.h>
Dhruvaraj Subhashchandran18b07862017-04-26 07:13:35 -050018#include <phosphor-logging/elog.hpp>
Matt Spinlera231ceb2017-10-04 11:26:09 -050019#include <phosphor-logging/elog-errors.hpp>
20#include <xyz/openbmc_project/Common/File/error.hpp>
21#include "filedescriptor.hpp"
Matt Spinler4e97ebe2017-02-28 10:02:16 -060022
23namespace openpower
24{
Matt Spinlerc3bffed2017-03-10 09:05:30 -060025namespace util
Matt Spinler4e97ebe2017-02-28 10:02:16 -060026{
27
Matt Spinlera231ceb2017-10-04 11:26:09 -050028namespace file_error = sdbusplus::xyz::openbmc_project::Common::File::Error;
29
Matt Spinler4e97ebe2017-02-28 10:02:16 -060030FileDescriptor::FileDescriptor(const std::string& path)
31{
Dhruvaraj Subhashchandran18b07862017-04-26 07:13:35 -050032 using namespace phosphor::logging;
33
Matt Spinler4e97ebe2017-02-28 10:02:16 -060034 fd = open(path.c_str(), O_RDWR | O_SYNC);
35
36 if (fd < 0)
37 {
Matt Spinlera231ceb2017-10-04 11:26:09 -050038 using metadata = xyz::openbmc_project::Common::File::Open;
39
40 elog<file_error::Open>(
41 metadata::ERRNO(errno),
42 metadata::PATH(path.c_str()));
Matt Spinler4e97ebe2017-02-28 10:02:16 -060043 }
44}
45
46
47FileDescriptor::~FileDescriptor()
48{
49 if (fd >= 0)
50 {
51 close(fd);
52 }
53}
54
55}
56}