blob: 04940487938bd3d36ba7979b0fe7e5364004a33d [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.
#pragma once
#include <ddk/binding.h>
#include <ddk/device.h>
#include <ddk/driver.h>
#include <ddk/protocol/amlogiccanvas.h>
#include <ddk/protocol/clock.h>
#include <ddk/protocol/ethernet/board.h>
#include <ddk/protocol/gpio.h>
#include <ddk/protocol/i2c.h>
#include <ddk/protocol/platform/device.h>
#include <ddk/protocol/power.h>
#include <ddk/protocol/sysmem.h>
#include <ddk/protocol/usb/modeswitch.h>
#include <ddktl/device.h>
#include <ddktl/protocol/mipicsi.h>
#include <lib/sync/completion.h>
#include <lib/zx/channel.h>
namespace component {
class Component;
using ComponentBase = ddk::Device<Component, ddk::Rxrpcable, ddk::Unbindable>;
class Component : public ComponentBase {
public:
explicit Component(zx_device_t* parent);
static zx_status_t Bind(void* ctx, zx_device_t* parent);
zx_status_t DdkRxrpc(zx_handle_t channel);
void DdkUnbind();
void DdkRelease();
private:
struct I2cTransactContext {
sync_completion_t completion;
void* read_buf;
size_t read_length;
zx_status_t result;
};
zx_status_t RpcCanvas(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* resp_handles,
uint32_t* resp_handle_count);
zx_status_t RpcMipiCsi(const uint8_t* req_buf, uint32_t req_size, uint8_t* resp_buf,
uint32_t* out_resp_size, const zx_handle_t* req_handles,
uint32_t req_handle_count, zx_handle_t* 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);
amlogic_canvas_protocol_t canvas_ = {};
clock_protocol_t clock_ = {};
eth_board_protocol_t eth_board_ = {};
gpio_protocol_t gpio_ = {};
i2c_protocol_t i2c_ = {};
mipi_csi_protocol_t mipicsi_ = {};
pdev_protocol_t pdev_ = {};
power_protocol_t power_ = {};
sysmem_protocol_t sysmem_ = {};
usb_mode_switch_protocol_t ums_ = {};
};
} // namespace component