blob: c91db015f192a3e160ba0ea02c68f81bfc316e6c [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.
#ifndef ZIRCON_SYSTEM_CORE_DEVMGR_COMPONENT_COMPONENT_H_
#define ZIRCON_SYSTEM_CORE_DEVMGR_COMPONENT_COMPONENT_H_
#include <lib/sync/completion.h>
#include <lib/zx/channel.h>
#include <ddk/binding.h>
#include <ddk/device.h>
#include <ddk/driver.h>
#include <ddktl/device.h>
#include <ddktl/protocol/amlogiccanvas.h>
#include <ddktl/protocol/buttons.h>
#include <ddktl/protocol/clock.h>
#include <ddktl/protocol/codec.h>
#include <ddktl/protocol/ethernet/board.h>
#include <ddktl/protocol/gpio.h>
#include <ddktl/protocol/i2c.h>
#include <ddktl/protocol/platform/device.h>
#include <ddktl/protocol/power.h>
#include <ddktl/protocol/pwm.h>
#include <ddktl/protocol/spi.h>
#include <ddktl/protocol/sysmem.h>
#include <ddktl/protocol/tee.h>
#include <ddktl/protocol/usb/modeswitch.h>
namespace component {
class Component;
using ComponentBase = ddk::Device<Component, ddk::Rxrpcable, ddk::UnbindableNew>;
class Component : public ComponentBase {
public:
explicit Component(zx_device_t* parent)
: ComponentBase(parent),
canvas_(parent),
buttons_(parent),
clock_(parent),
eth_board_(parent),
gpio_(parent),
i2c_(parent),
codec_(parent),
pdev_(parent),
power_(parent),
pwm_(parent),
spi_(parent),
sysmem_(parent),
tee_(parent),
ums_(parent) {}
static zx_status_t Bind(void* ctx, zx_device_t* parent);
zx_status_t DdkRxrpc(zx_handle_t channel);
void DdkUnbindNew(ddk::UnbindTxn txn);
void DdkRelease();
private:
struct I2cTransactContext {
sync_completion_t completion;
void* read_buf;
size_t read_length;
zx_status_t result;
};
struct CodecTransactContext {
sync_completion_t completion;
zx_status_t status;
void* buffer;
size_t size;
};
zx_status_t RpcCanvas(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcButtons(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles,
uint32_t req_handle_count, zx::handle* resp_handles,
uint32_t* resp_handle_count);
zx_status_t RpcClock(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcEthBoard(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles,
uint32_t req_handle_count, zx::handle* resp_handles,
uint32_t* resp_handle_count);
zx_status_t RpcGpio(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcI2c(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcPdev(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcPower(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcPwm(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcSpi(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcSysmem(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcTee(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcUms(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
zx_status_t RpcCodec(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, zx::handle* req_handles, uint32_t req_handle_count,
zx::handle* resp_handles, uint32_t* resp_handle_count);
static void I2cTransactCallback(void* cookie, zx_status_t status, const i2c_op_t* op_list,
size_t op_count);
static void CodecTransactCallback(void* cookie, zx_status_t status,
const dai_supported_formats_t* formats_list,
size_t formats_count);
ddk::AmlogicCanvasProtocolClient canvas_;
ddk::ButtonsProtocolClient buttons_;
ddk::ClockProtocolClient clock_;
ddk::EthBoardProtocolClient eth_board_;
ddk::GpioProtocolClient gpio_;
ddk::I2cProtocolClient i2c_;
ddk::CodecProtocolClient codec_;
ddk::PDevProtocolClient pdev_;
ddk::PowerProtocolClient power_;
ddk::PwmProtocolClient pwm_;
ddk::SpiProtocolClient spi_;
ddk::SysmemProtocolClient sysmem_;
ddk::TeeProtocolClient tee_;
ddk::UsbModeSwitchProtocolClient ums_;
};
} // namespace component
#endif // ZIRCON_SYSTEM_CORE_DEVMGR_COMPONENT_COMPONENT_H_