blob: ae53167d328bcc9fcbf77035fa3bb4fe191384cd [file] [log] [blame]
// Copyright 2019 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "sysinfo.h"
#include <fcntl.h>
#include <lib/fdio/directory.h>
#include <lib/fdio/fdio.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <threads.h>
#include <zircon/process.h>
#include <zircon/processargs.h>
#include <zircon/syscalls/resource.h>
#include <zircon/types.h>
#include <fbl/unique_fd.h>
namespace sysinfo {
void SysInfo::GetBoardName(GetBoardNameRequestView request,
GetBoardNameCompleter::Sync &completer) {
std::string board_name;
zx_status_t status = GetBoardName(&board_name);
completer.Reply(status, fidl::StringView::FromExternal(board_name));
}
void SysInfo::GetBoardRevision(GetBoardRevisionRequestView request,
GetBoardRevisionCompleter::Sync &completer) {
uint32_t revision;
zx_status_t status = GetBoardRevision(&revision);
completer.Reply(status, revision);
}
void SysInfo::GetBootloaderVendor(GetBootloaderVendorRequestView request,
GetBootloaderVendorCompleter::Sync &completer) {
std::string bootloader_vendor;
zx_status_t status = GetBootloaderVendor(&bootloader_vendor);
completer.Reply(status, fidl::StringView::FromExternal(bootloader_vendor));
}
void SysInfo::GetInterruptControllerInfo(GetInterruptControllerInfoRequestView request,
GetInterruptControllerInfoCompleter::Sync &completer) {
fuchsia_sysinfo::wire::InterruptControllerInfo info = {};
zx_status_t status = GetInterruptControllerInfo(&info);
completer.Reply(
status,
fidl::ObjectView<fuchsia_sysinfo::wire::InterruptControllerInfo>::FromExternal(&info));
}
zx_status_t SysInfo::GetBoardName(std::string *board_name) {
fidl::WireSyncClient<fuchsia_sysinfo::SysInfo> client;
zx_status_t status = ConnectToPBus(&client);
if (status != ZX_OK) {
return status;
}
// Get board name from platform bus
auto result = client->GetBoardName();
if (!result.ok()) {
printf("sysinfo: Could not GetBoardName: %s\n", result.FormatDescription().c_str());
return result.status();
}
*board_name = std::string(result->name.cbegin(), result->name.size());
return status;
}
zx_status_t SysInfo::GetBoardRevision(uint32_t *board_revision) {
fidl::WireSyncClient<fuchsia_sysinfo::SysInfo> client;
zx_status_t status = ConnectToPBus(&client);
if (status != ZX_OK) {
return status;
}
// Get board revision from platform bus
auto result = client->GetBoardRevision();
if (!result.ok()) {
printf("sysinfo: Could not GetBoardRevision: %s\n", result.FormatDescription().c_str());
return result.status();
}
*board_revision = result->revision;
return status;
}
zx_status_t SysInfo::GetBootloaderVendor(std::string *bootloader_vendor) {
fidl::WireSyncClient<fuchsia_sysinfo::SysInfo> client;
zx_status_t status = ConnectToPBus(&client);
if (status != ZX_OK) {
return status;
}
// Get bootloader vendor from platform bus
auto result = client->GetBootloaderVendor();
if (!result.ok()) {
printf("sysinfo: Could not GetBootloaderVendor: %s\n", result.FormatDescription().c_str());
return result.status();
}
*bootloader_vendor = std::string(result->vendor.cbegin(), result->vendor.size());
return status;
}
zx_status_t SysInfo::GetInterruptControllerInfo(
fuchsia_sysinfo::wire::InterruptControllerInfo *info) {
fidl::WireSyncClient<fuchsia_sysinfo::SysInfo> client;
zx_status_t status = ConnectToPBus(&client);
if (status != ZX_OK) {
return status;
}
// Get interrupt controller information from platform bus
auto result = client->GetInterruptControllerInfo();
if (!result.ok()) {
printf("sysinfo: Could not GetInterruptControllerInfo: %s\n",
result.FormatDescription().c_str());
return result.status();
}
info->type = result->info->type;
return status;
}
zx_status_t SysInfo::ConnectToPBus(fidl::WireSyncClient<fuchsia_sysinfo::SysInfo> *client) {
zx::status endpoints = fidl::CreateEndpoints<fuchsia_sysinfo::SysInfo>();
if (!endpoints.is_ok()) {
printf("sysinfo: Channel create failed: %s\n", endpoints.status_string());
return endpoints.status_value();
}
client->Bind(std::move(endpoints->client));
zx_status_t status =
fdio_service_connect("/dev/sys/platform", endpoints->server.TakeChannel().release());
if (status != ZX_OK) {
printf("sysinfo: Could not connect to platform bus: %s\n", zx_status_get_string(status));
return status;
}
return ZX_OK;
}
} // namespace sysinfo