| // SPDX-License-Identifier: GPL-2.0 |
| /* |
| * Author: Huacai Chen <chenhuacai@loongson.cn> |
| * Copyright (C) 2020-2022 Loongson Technology Corporation Limited |
| */ |
| #include <linux/acpi.h> |
| #include <linux/platform_device.h> |
| |
| #include <asm/bootinfo.h> |
| #include <asm/loongson.h> |
| |
| void enable_gpe_wakeup(void) |
| { |
| if (acpi_disabled) |
| return; |
| |
| if (acpi_gbl_reduced_hardware) |
| return; |
| |
| acpi_enable_all_wakeup_gpes(); |
| } |
| |
| void enable_pci_wakeup(void) |
| { |
| if (acpi_disabled) |
| return; |
| |
| if (acpi_gbl_reduced_hardware) |
| return; |
| |
| acpi_write_bit_register(ACPI_BITREG_PCIEXP_WAKE_STATUS, 1); |
| |
| if (acpi_gbl_FADT.flags & ACPI_FADT_PCI_EXPRESS_WAKE) |
| acpi_write_bit_register(ACPI_BITREG_PCIEXP_WAKE_DISABLE, 0); |
| } |
| |
| static struct platform_device loongson3_cpufreq_device = { |
| .name = "loongson3_cpufreq", |
| .id = -1, |
| }; |
| |
| static int __init loongson_cpufreq_init(void) |
| { |
| if (!cpu_has_scalefreq) |
| return -ENODEV; |
| |
| return platform_device_register(&loongson3_cpufreq_device); |
| } |
| |
| arch_initcall(loongson_cpufreq_init); |
| |
| static void default_suspend_addr(void) |
| { |
| acpi_enter_sleep_state(ACPI_STATE_S3); |
| } |
| |
| static int __init loongson3_acpi_suspend_init(void) |
| { |
| #ifdef CONFIG_ACPI |
| acpi_status status; |
| uint64_t suspend_addr = 0; |
| |
| if (acpi_disabled) |
| return 0; |
| |
| if (!acpi_gbl_reduced_hardware) |
| acpi_write_bit_register(ACPI_BITREG_SCI_ENABLE, 1); |
| |
| if (!acpi_sleep_state_supported(ACPI_STATE_S3)) |
| return 0; |
| |
| status = acpi_evaluate_integer(NULL, "\\SADR", NULL, &suspend_addr); |
| if (ACPI_FAILURE(status) || !suspend_addr) { |
| pr_info("ACPI S3 supported with hardware register default\n"); |
| loongson_sysconf.suspend_addr = (u64)default_suspend_addr; |
| } else { |
| pr_info("ACPI S3 supported with Loongson ACPI SADR extension\n"); |
| loongson_sysconf.suspend_addr = (u64)phys_to_virt(PHYSADDR(suspend_addr)); |
| } |
| #endif |
| return 0; |
| } |
| |
| device_initcall(loongson3_acpi_suspend_init); |