cregit-Linux how code gets into the kernel

Release 4.15 arch/x86/kernel/time.c

Directory: arch/x86/kernel
// SPDX-License-Identifier: GPL-2.0
/*
 *  Copyright (c) 1991,1992,1995  Linus Torvalds
 *  Copyright (c) 1994  Alan Modra
 *  Copyright (c) 1995  Markus Kuhn
 *  Copyright (c) 1996  Ingo Molnar
 *  Copyright (c) 1998  Andrea Arcangeli
 *  Copyright (c) 2002,2006  Vojtech Pavlik
 *  Copyright (c) 2003  Andi Kleen
 *
 */

#include <linux/clockchips.h>
#include <linux/interrupt.h>
#include <linux/i8253.h>
#include <linux/time.h>
#include <linux/export.h>

#include <asm/vsyscall.h>
#include <asm/x86_init.h>
#include <asm/i8259.h>
#include <asm/timer.h>
#include <asm/hpet.h>
#include <asm/time.h>

#ifdef CONFIG_X86_64

__visible volatile unsigned long jiffies __cacheline_aligned = INITIAL_JIFFIES;
#endif


unsigned long profile_pc(struct pt_regs *regs) { unsigned long pc = instruction_pointer(regs); if (!user_mode(regs) && in_lock_functions(pc)) { #ifdef CONFIG_FRAME_POINTER return *(unsigned long *)(regs->bp + sizeof(long)); #else unsigned long *sp = (unsigned long *)kernel_stack_pointer(regs); /* * Return address is either directly at stack pointer * or above a saved flags. Eflags has bits 22-31 zero, * kernel addresses don't. */ if (sp[0] >> 22) return sp[0]; if (sp[1] >> 22) return sp[1]; #endif } return pc; }

Contributors

PersonTokensPropCommitsCommitProp
Andi Kleen4844.04%333.33%
Zwane Mwaikambo2825.69%111.11%
Glauber de Oliveira Costa2522.94%111.11%
Anton Blanchard32.75%111.11%
H. Peter Anvin32.75%111.11%
Andrew Lutomirski10.92%111.11%
Thomas Gleixner10.92%111.11%
Total109100.00%9100.00%

EXPORT_SYMBOL(profile_pc); /* * Default timer interrupt handler for PIT/HPET */
static irqreturn_t timer_interrupt(int irq, void *dev_id) { global_clock_event->event_handler(global_clock_event); return IRQ_HANDLED; }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner2191.30%133.33%
Glauber de Oliveira Costa14.35%133.33%
Jaswinder Singh Rajput14.35%133.33%
Total23100.00%3100.00%

static struct irqaction irq0 = { .handler = timer_interrupt, .flags = IRQF_NOBALANCING | IRQF_IRQPOLL | IRQF_TIMER, .name = "timer" };
static void __init setup_default_timer_irq(void) { if (!nr_legacy_irqs()) return; setup_irq(0, &irq0); }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner1666.67%133.33%
Andy Shevchenko729.17%133.33%
Dou Liyang14.17%133.33%
Total24100.00%3100.00%

/* Default timer init function */
void __init hpet_time_init(void) { if (!hpet_enable()) setup_pit_timer(); setup_default_timer_irq(); }

Contributors

PersonTokensPropCommitsCommitProp
John Stultz735.00%233.33%
Andi Kleen630.00%116.67%
Thomas Gleixner525.00%233.33%
Glauber de Oliveira Costa210.00%116.67%
Total20100.00%6100.00%


static __init void x86_late_time_init(void) { x86_init.timers.timer_init(); /* * After PIT/HPET timers init, select and setup * the final interrupt mode for delivering IRQs. */ x86_init.irqs.intr_mode_init(); tsc_init(); }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner1970.37%375.00%
Dou Liyang829.63%125.00%
Total27100.00%4100.00%

/* * Initialize TSC and delay the periodic timer init to * late x86_late_time_init() so ioremap works. */
void __init time_init(void) { late_time_init = x86_late_time_init; }

Contributors

PersonTokensPropCommitsCommitProp
Glauber de Oliveira Costa1083.33%133.33%
Thomas Gleixner18.33%133.33%
Andi Kleen18.33%133.33%
Total12100.00%3100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner8227.52%923.68%
Andi Kleen7625.50%923.68%
Glauber de Oliveira Costa4214.09%37.89%
Zwane Mwaikambo3311.07%12.63%
John Stultz186.04%25.26%
Bernhard Walle93.02%12.63%
Dou Liyang93.02%25.26%
Andy Shevchenko72.35%12.63%
Ralf Bächle51.68%12.63%
H. Peter Anvin31.01%12.63%
Paul Gortmaker31.01%12.63%
Andrew Lutomirski31.01%25.26%
Anton Blanchard31.01%12.63%
Linus Torvalds20.67%12.63%
Jaswinder Singh Rajput10.34%12.63%
Venkatesh Pallipadi10.34%12.63%
Greg Kroah-Hartman10.34%12.63%
Total298100.00%38100.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.