cregit-Linux how code gets into the kernel

Release 4.14 arch/x86/kernel/devicetree.c

Directory: arch/x86/kernel
// SPDX-License-Identifier: GPL-2.0
/*
 * Architecture specific OF callbacks.
 */
#include <linux/bootmem.h>
#include <linux/export.h>
#include <linux/io.h>
#include <linux/interrupt.h>
#include <linux/list.h>
#include <linux/of.h>
#include <linux/of_fdt.h>
#include <linux/of_address.h>
#include <linux/of_platform.h>
#include <linux/of_irq.h>
#include <linux/slab.h>
#include <linux/pci.h>
#include <linux/of_pci.h>
#include <linux/initrd.h>

#include <asm/irqdomain.h>
#include <asm/hpet.h>
#include <asm/apic.h>
#include <asm/pci_x86.h>
#include <asm/setup.h>
#include <asm/i8259.h>


__initdata u64 initial_dtb;

char __initdata cmd_line[COMMAND_LINE_SIZE];


int __initdata of_ioapic;


void __init early_init_dt_scan_chosen_arch(unsigned long node) { BUG(); }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior13100.00%1100.00%
Total13100.00%1100.00%


void __init early_init_dt_add_memory_arch(u64 base, u64 size) { BUG(); }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior15100.00%1100.00%
Total15100.00%1100.00%


void * __init early_init_dt_alloc_memory_arch(u64 size, u64 align) { return __alloc_bootmem(size, align, __pa(MAX_DMA_ADDRESS)); }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior26100.00%1100.00%
Total26100.00%1100.00%


void __init add_dtb(u64 data) { initial_dtb = data + offsetof(struct setup_data, data); }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior21100.00%2100.00%
Total21100.00%2100.00%

/* * CE4100 ids. Will be moved to machine_device_initcall() once we have it. */ static struct of_device_id __initdata ce4100_ids[] = { { .compatible = "intel,ce4100-cp", }, { .compatible = "isa", }, { .compatible = "pci", }, {}, };
static int __init add_bus_probe(void) { if (!of_have_populated_dt()) return 0; return of_platform_bus_probe(NULL, ce4100_ids, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior28100.00%2100.00%
Total28100.00%2100.00%

device_initcall(add_bus_probe); #ifdef CONFIG_PCI
struct device_node *pcibios_get_phb_of_node(struct pci_bus *bus) { struct device_node *np; for_each_node_by_type(np, "pci") { const void *prop; unsigned int bus_min; prop = of_get_property(np, "bus-range", NULL); if (!prop) continue; bus_min = be32_to_cpup(prop); if (bus->number == bus_min) return np; } return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
Benjamin Herrenschmidt72100.00%1100.00%
Total72100.00%1100.00%


static int x86_of_pci_irq_enable(struct pci_dev *dev) { u32 virq; int ret; u8 pin; ret = pci_read_config_byte(dev, PCI_INTERRUPT_PIN, &pin); if (ret) return ret; if (!pin) return 0; virq = of_irq_parse_and_map_pci(dev, 0, 0); if (virq == 0) return -EINVAL; dev->irq = virq; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior7496.10%150.00%
Grant C. Likely33.90%150.00%
Total77100.00%2100.00%


static void x86_of_pci_irq_disable(struct pci_dev *dev) { }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior10100.00%1100.00%
Total10100.00%1100.00%


void x86_of_pci_init(void) { pcibios_enable_irq = x86_of_pci_irq_enable; pcibios_disable_irq = x86_of_pci_irq_disable; }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior15100.00%1100.00%
Total15100.00%1100.00%

#endif
static void __init dtb_setup_hpet(void) { #ifdef CONFIG_HPET_TIMER struct device_node *dn; struct resource r; int ret; dn = of_find_compatible_node(NULL, NULL, "intel,ce4100-hpet"); if (!dn) return; ret = of_address_to_resource(dn, 0, &r); if (ret) { WARN_ON(1); return; } hpet_address = r.start; #endif }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior73100.00%2100.00%
Total73100.00%2100.00%


static void __init dtb_lapic_setup(void) { #ifdef CONFIG_X86_LOCAL_APIC struct device_node *dn; struct resource r; int ret; dn = of_find_compatible_node(NULL, NULL, "intel,ce4100-lapic"); if (!dn) return; ret = of_address_to_resource(dn, 0, &r); if (WARN_ON(ret)) return; /* Did the boot loader setup the local APIC ? */ if (!boot_cpu_has(X86_FEATURE_APIC)) { if (apic_force_enable(r.start)) return; } smp_found_config = 1; pic_mode = 1; register_lapic_address(r.start); generic_processor_info(boot_cpu_physical_apicid, GET_APIC_VERSION(apic_read(APIC_LVR))); #endif }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner6558.04%133.33%
Sebastian Andrzej Siewior4338.39%133.33%
Borislav Petkov43.57%133.33%
Total112100.00%3100.00%

#ifdef CONFIG_X86_IO_APIC static unsigned int ioapic_id; struct of_ioapic_type { u32 out_type; u32 trigger; u32 polarity; }; static struct of_ioapic_type of_ioapic_type[] = { { .out_type = IRQ_TYPE_EDGE_RISING, .trigger = IOAPIC_EDGE, .polarity = 1, }, { .out_type = IRQ_TYPE_LEVEL_LOW, .trigger = IOAPIC_LEVEL, .polarity = 0, }, { .out_type = IRQ_TYPE_LEVEL_HIGH, .trigger = IOAPIC_LEVEL, .polarity = 1, }, { .out_type = IRQ_TYPE_EDGE_FALLING, .trigger = IOAPIC_EDGE, .polarity = 0, }, };
static int dt_irqdomain_alloc(struct irq_domain *domain, unsigned int virq, unsigned int nr_irqs, void *arg) { struct of_phandle_args *irq_data = (void *)arg; struct of_ioapic_type *it; struct irq_alloc_info tmp; if (WARN_ON(irq_data->args_count < 2)) return -EINVAL; if (irq_data->args[1] >= ARRAY_SIZE(of_ioapic_type)) return -EINVAL; it = &of_ioapic_type[irq_data->args[1]]; ioapic_set_alloc_attr(&tmp, NUMA_NO_NODE, it->trigger, it->polarity); tmp.ioapic_id = mpc_ioapic_id(mp_irqdomain_ioapic_idx(domain)); tmp.ioapic_pin = irq_data->args[0]; return mp_irqdomain_alloc(domain, virq, nr_irqs, &tmp); }

Contributors

PersonTokensPropCommitsCommitProp
Jiang Liu6546.10%133.33%
Sebastian Andrzej Siewior5740.43%133.33%
Grant C. Likely1913.48%133.33%
Total141100.00%3100.00%

static const struct irq_domain_ops ioapic_irq_domain_ops = { .alloc = dt_irqdomain_alloc, .free = mp_irqdomain_free, .activate = mp_irqdomain_activate, .deactivate = mp_irqdomain_deactivate, };
static void __init dtb_add_ioapic(struct device_node *dn) { struct resource r; int ret; struct ioapic_domain_cfg cfg = { .type = IOAPIC_DOMAIN_DYNAMIC, .ops = &ioapic_irq_domain_ops, .dev = dn, }; ret = of_address_to_resource(dn, 0, &r); if (ret) { printk(KERN_ERR "Can't obtain address from device node %pOF.\n", dn); return; } mp_register_ioapic(++ioapic_id, r.start, gsi_top, &cfg); }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior4453.01%125.00%
Jiang Liu3744.58%125.00%
Rob Herring11.20%125.00%
Suresh B. Siddha11.20%125.00%
Total83100.00%4100.00%


static void __init dtb_ioapic_setup(void) { struct device_node *dn; for_each_compatible_node(dn, NULL, "intel,ce4100-ioapic") dtb_add_ioapic(dn); if (nr_ioapics) { of_ioapic = 1; return; } printk(KERN_ERR "Error: No information about IO-APIC in OF.\n"); }

Contributors

PersonTokensPropCommitsCommitProp
Jiang Liu3170.45%133.33%
Sebastian Andrzej Siewior1227.27%133.33%
Grant C. Likely12.27%133.33%
Total44100.00%3100.00%

#else
static void __init dtb_ioapic_setup(void) {}

Contributors

PersonTokensPropCommitsCommitProp
Jiang Liu8100.00%1100.00%
Total8100.00%1100.00%

#endif
static void __init dtb_apic_setup(void) { dtb_lapic_setup(); dtb_ioapic_setup(); }

Contributors

PersonTokensPropCommitsCommitProp
Jiang Liu960.00%150.00%
Sebastian Andrzej Siewior640.00%150.00%
Total15100.00%2100.00%

#ifdef CONFIG_OF_FLATTREE
static void __init x86_flattree_get_config(void) { u32 size, map_len; void *dt; if (!initial_dtb) return; map_len = max(PAGE_SIZE - (initial_dtb & ~PAGE_MASK), (u64)128); initial_boot_params = dt = early_memremap(initial_dtb, map_len); size = of_get_flat_dt_size(); if (map_len < size) { early_memunmap(dt, map_len); initial_boot_params = dt = early_memremap(initial_dtb, size); map_len = size; } unflatten_and_copy_device_tree(); early_memunmap(dt, map_len); }

Contributors

PersonTokensPropCommitsCommitProp
Jiang Liu7777.78%133.33%
Sebastian Andrzej Siewior2020.20%133.33%
Juergen Gross22.02%133.33%
Total99100.00%3100.00%

#else
static inline void x86_flattree_get_config(void) { }

Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior562.50%150.00%
Jiang Liu337.50%150.00%
Total8100.00%2100.00%

#endif
void __init x86_dtb_init(void) { x86_flattree_get_config(); if (!of_have_populated_dt()) return; dtb_setup_hpet(); dtb_apic_setup(); }

Contributors

PersonTokensPropCommitsCommitProp
Jiang Liu24100.00%1100.00%
Total24100.00%1100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Sebastian Andrzej Siewior66758.46%829.63%
Jiang Liu28524.98%518.52%
Benjamin Herrenschmidt726.31%13.70%
Thomas Gleixner696.05%27.41%
Grant C. Likely292.54%27.41%
Paul Gortmaker40.35%27.41%
Rob Herring40.35%27.41%
Borislav Petkov40.35%13.70%
Florian Fainelli30.26%13.70%
Juergen Gross20.18%13.70%
Suresh B. Siddha10.09%13.70%
Greg Kroah-Hartman10.09%13.70%
Total1141100.00%27100.00%
Directory: arch/x86/kernel
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.