|
Packit |
534379 |
// Copyright(c) 2018, Intel Corporation
|
|
Packit |
534379 |
//
|
|
Packit |
534379 |
// Redistribution and use in source and binary forms, with or without
|
|
Packit |
534379 |
// modification, are permitted provided that the following conditions are met:
|
|
Packit |
534379 |
//
|
|
Packit |
534379 |
// * Redistributions of source code must retain the above copyright notice,
|
|
Packit |
534379 |
// this list of conditions and the following disclaimer.
|
|
Packit |
534379 |
// * Redistributions in binary form must reproduce the above copyright notice,
|
|
Packit |
534379 |
// this list of conditions and the following disclaimer in the documentation
|
|
Packit |
534379 |
// and/or other materials provided with the distribution.
|
|
Packit |
534379 |
// * Neither the name of Intel Corporation nor the names of its contributors
|
|
Packit |
534379 |
// may be used to endorse or promote products derived from this software
|
|
Packit |
534379 |
// without specific prior written permission.
|
|
Packit |
534379 |
//
|
|
Packit |
534379 |
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
Packit |
534379 |
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
Packit |
534379 |
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
Packit |
534379 |
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
Packit |
534379 |
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
Packit |
534379 |
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
Packit |
534379 |
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
Packit |
534379 |
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
Packit |
534379 |
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
Packit |
534379 |
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
Packit |
534379 |
// POSSIBILITY OF SUCH DAMAGE.
|
|
Packit |
534379 |
#include "pyerrors.h"
|
|
Packit |
534379 |
namespace py = pybind11;
|
|
Packit |
534379 |
using opae::fpga::types::error;
|
|
Packit |
534379 |
using opae::fpga::types::token;
|
|
Packit |
534379 |
using opae::fpga::types::properties;
|
|
Packit |
534379 |
|
|
Packit |
534379 |
const char *error_doc() {
|
|
Packit |
534379 |
return R"opaedoc(
|
|
Packit |
534379 |
error object is used to represent an error register in an FPGA resource.
|
|
Packit |
534379 |
It holds two read-only properties, `name` and `can_clear` and it can also
|
|
Packit |
534379 |
be used to read the raw register value from its corresponding error register.
|
|
Packit |
534379 |
)opaedoc";
|
|
Packit |
534379 |
}
|
|
Packit |
534379 |
|
|
Packit |
534379 |
const char *error_doc_name() {
|
|
Packit |
534379 |
return R"opaedoc(
|
|
Packit |
534379 |
Error register name - read-only property
|
|
Packit |
534379 |
)opaedoc";
|
|
Packit |
534379 |
}
|
|
Packit |
534379 |
|
|
Packit |
534379 |
|
|
Packit |
534379 |
const char *error_doc_can_clear() {
|
|
Packit |
534379 |
return R"opaedoc(
|
|
Packit |
534379 |
Indicates if the error register can be cleared - read-only property
|
|
Packit |
534379 |
)opaedoc";
|
|
Packit |
534379 |
}
|
|
Packit |
534379 |
|
|
Packit |
534379 |
const char *error_doc_read_value() {
|
|
Packit |
534379 |
return R"opaedoc(
|
|
Packit |
534379 |
Read the raw value from the error register.
|
|
Packit |
534379 |
)opaedoc";
|
|
Packit |
534379 |
}
|
|
Packit |
534379 |
|
|
Packit |
534379 |
const char *error_doc_errors() {
|
|
Packit |
534379 |
return R"opaedoc(
|
|
Packit |
534379 |
Get a list of error objects in an FPGA resource.
|
|
Packit |
534379 |
Each error object represents an error register contained in the resource.
|
|
Packit |
534379 |
|
|
Packit |
534379 |
Args:
|
|
Packit |
534379 |
tok(token): Token representing an FPGA resource.
|
|
Packit |
534379 |
)opaedoc";
|
|
Packit |
534379 |
}
|
|
Packit |
534379 |
|
|
Packit |
534379 |
std::vector<error::ptr_t> error_errors(token::ptr_t tok) {
|
|
Packit |
534379 |
auto props = properties::get(tok);
|
|
Packit |
534379 |
std::vector<error::ptr_t> errors(props->num_errors);
|
|
Packit |
534379 |
for (uint32_t i = 0; i < props->num_errors; ++i) {
|
|
Packit |
534379 |
errors[i] = error::get(tok, i);
|
|
Packit |
534379 |
}
|
|
Packit |
534379 |
return errors;
|
|
Packit |
534379 |
}
|
|
Packit |
534379 |
|