Add Non-Uniform Memory Access (NUMA) support for LoongArch. LoongArch has 48-bit physical address, but the HyperTransport I/O bus only support 40-bit address, so we need a custom phys_to_dma() and dma_to_phys() to extract the 4-bit node id (bit 44~47) from Loongson-3's 48-bit physical address space and embed it into 40-bit. In the 40-bit dma address, node id offset can be read from the LS7A_DMA_CFG register. Reviewed-by: WANG Xuerui <git@xen0n.name> Reviewed-by: Jiaxun Yang <jiaxun.yang@flygoat.com> Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
44 lines
988 B
C
44 lines
988 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (C) 2020-2022 Loongson Technology Corporation Limited
|
|
*/
|
|
#ifndef _ASM_BOOTINFO_H
|
|
#define _ASM_BOOTINFO_H
|
|
|
|
#include <linux/types.h>
|
|
#include <asm/setup.h>
|
|
|
|
const char *get_system_type(void);
|
|
|
|
extern void init_environ(void);
|
|
extern void memblock_init(void);
|
|
extern void platform_init(void);
|
|
extern void plat_swiotlb_setup(void);
|
|
extern int __init init_numa_memory(void);
|
|
|
|
struct loongson_board_info {
|
|
int bios_size;
|
|
const char *bios_vendor;
|
|
const char *bios_version;
|
|
const char *bios_release_date;
|
|
const char *board_name;
|
|
const char *board_vendor;
|
|
};
|
|
|
|
struct loongson_system_configuration {
|
|
int nr_cpus;
|
|
int nr_nodes;
|
|
int nr_io_pics;
|
|
int boot_cpu_id;
|
|
int cores_per_node;
|
|
int cores_per_package;
|
|
const char *cpuname;
|
|
};
|
|
|
|
extern u64 efi_system_table;
|
|
extern unsigned long fw_arg0, fw_arg1;
|
|
extern struct loongson_board_info b_info;
|
|
extern struct loongson_system_configuration loongson_sysconf;
|
|
|
|
#endif /* _ASM_BOOTINFO_H */
|