| // Copyright 2020 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 <ddk/binding.h> |
| #include <ddk/debug.h> |
| #include <ddk/device.h> |
| #include <ddk/metadata.h> |
| #include <ddk/platform-defs.h> |
| #include <soc/aml-common/aml-registers.h> |
| |
| #include "sherlock.h" |
| #include "src/devices/lib/metadata/llcpp/registers.h" |
| |
| namespace sherlock { |
| |
| namespace { |
| |
| enum MmioMetadataIdx { |
| #ifdef FACTORY_BUILD |
| USB_FACTORY_MMIO, |
| #endif // FACTORY_BUILD |
| |
| MMIO_COUNT, |
| }; |
| |
| } // namespace |
| |
| zx_status_t Sherlock::RegistersInit() { |
| const pbus_mmio_t registers_mmios[] = { |
| #ifdef FACTORY_BUILD |
| { |
| .base = T931_USB_BASE, |
| .length = T931_USB_LENGTH, |
| }, |
| #endif // FACTORY_BUILD |
| }; |
| |
| auto mmio_entries = std::make_unique<registers::MmioMetadataEntry[]>(MMIO_COUNT); |
| auto register_entries = |
| std::make_unique<registers::RegistersMetadataEntry[]>(registers::REGISTER_ID_COUNT); |
| |
| #ifdef FACTORY_BUILD |
| mmio_entries[USB_FACTORY_MMIO] = registers::BuildMetadata(T931_USB_BASE); |
| |
| register_entries[registers::REGISTER_USB_PHY_FACTORY] = registers::BuildMetadata( |
| registers::REGISTER_USB_PHY_FACTORY, T931_USB_BASE, |
| std::vector<std::pair<uint32_t, uint32_t>>{{0xFFFFFFFF, T931_USB_LENGTH / sizeof(uint32_t)}}); |
| #endif // FACTORY_BUILD |
| |
| auto metadata = |
| registers::BuildMetadata(std::move(mmio_entries), MMIO_COUNT, std::move(register_entries), |
| registers::REGISTER_ID_COUNT); |
| fidl::OwnedOutgoingMessage<registers::Metadata> encoded_metadata(&metadata); |
| if (!encoded_metadata.ok() || (encoded_metadata.error() != nullptr)) { |
| zxlogf(ERROR, "%s: Could not build metadata %s\n", __FILE__, encoded_metadata.error()); |
| return encoded_metadata.status(); |
| } |
| |
| const pbus_metadata_t registers_metadata[] = { |
| { |
| .type = DEVICE_METADATA_REGISTERS, |
| .data_buffer = encoded_metadata.GetOutgoingMessage().bytes(), |
| .data_size = encoded_metadata.GetOutgoingMessage().byte_actual(), |
| }, |
| }; |
| |
| pbus_dev_t registers_dev{ |
| .name = "registers", |
| .vid = PDEV_VID_GENERIC, |
| .pid = PDEV_PID_GENERIC, |
| .did = PDEV_DID_REGISTERS, |
| .mmio_list = registers_mmios, |
| .mmio_count = countof(registers_mmios), |
| .metadata_list = registers_metadata, |
| .metadata_count = countof(registers_metadata), |
| }; |
| |
| zx_status_t status = pbus_.DeviceAdd(®isters_dev); |
| if (status != ZX_OK) { |
| zxlogf(ERROR, "%s: DeviceAdd failed %d", __func__, status); |
| return status; |
| } |
| |
| return ZX_OK; |
| } |
| |
| } // namespace sherlock |