/* SPDX-License-Identifier: GPL-2.0-only */ #include #include #include #include #include #include static void soc_read_resources(struct device *dev) { void *start = NULL; void *end = NULL; ram_resource_kb(dev, 0, (uintptr_t)ddr_region->offset / KiB, ddr_region->size / KiB); reserved_ram_resource_kb(dev, 1, (uintptr_t)_dram_aop / KiB, REGION_SIZE(dram_aop) / KiB); reserved_ram_resource_kb(dev, 2, (uintptr_t)_dram_soc / KiB, REGION_SIZE(dram_soc) / KiB); if (soc_modem_carve_out(&start, &end)) reserved_ram_resource_kb(dev, 3, (uintptr_t)start / KiB, (end - start) / KiB); } static void soc_init(struct device *dev) { aop_fw_load_reset(); } static struct device_operations soc_ops = { .read_resources = soc_read_resources, .init = soc_init, }; static void enable_soc_dev(struct device *dev) { dev->ops = &soc_ops; } struct chip_operations soc_qualcomm_sc7180_ops = { CHIP_NAME("SOC Qualcomm SC7180") .enable_dev = enable_soc_dev, };