blob: 0ce40aaa9d7e7a76e15131011444c0057f971138 [file] [log] [blame]
// Copyright 2017 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/device.h>
#include <ddk/io-buffer.h>
#include <ddk/protocol/gpio.h>
#include <ddk/protocol/i2c.h>
#include <ddk/protocol/iommu.h>
#include <ddk/protocol/platform-bus.h>
#include <ddk/protocol/serial.h>
#define BIG_CLUSTER_POWER_DOMAIN 0
#define LITTLE_CLUSTER_POWER_DOMAIN 1
#define BIG_CLUSTER_CPU_FREQ_MAX 1200000000
#define LITTLE_CLUSTER_CPU_FREQ_MAX 1000000000
// BTI IDs for our devices
enum {
BTI_BOARD,
BTI_USB_XHCI,
BTI_MALI,
BTI_DISPLAY,
BTI_VIDEO,
BTI_EMMC,
BTI_SDIO,
};
typedef struct {
platform_bus_protocol_t pbus;
gpio_protocol_t gpio;
i2c_protocol_t i2c;
serial_impl_protocol_t serial;
zx_device_t* parent;
iommu_protocol_t iommu;
} vim_bus_t;
// vim-gpio.c
zx_status_t vim_gpio_init(vim_bus_t* bus);
// vim-i2c.c
zx_status_t vim_i2c_init(vim_bus_t* bus);
// vim-mali.c
zx_status_t vim_mali_init(vim_bus_t* bus, uint32_t bti_index);
// vim-uart.c
zx_status_t vim_uart_init(vim_bus_t* bus);
// vim-usb.c
zx_status_t vim_usb_init(vim_bus_t* bus);
// vim-sd-emmc.c
zx_status_t vim_sd_emmc_init(vim_bus_t* bus);
// vim-sd-emmc.c
zx_status_t vim_sdio_init(vim_bus_t* bus);
// vim-eth.c
zx_status_t vim_eth_init(vim_bus_t* bus);
// vim-fanctl.c
zx_status_t vim2_thermal_init(vim_bus_t* bus);
// vim-mailbox.c
zx_status_t vim2_mailbox_init(vim_bus_t* bus);
// vim-display.c
zx_status_t vim_display_init(vim_bus_t* bus);
// vim-video.c
zx_status_t vim_video_init(vim_bus_t* bus);
// vim-led2472g.c
zx_status_t vim_led2472g_init(vim_bus_t* bus);