cregit-Linux how code gets into the kernel

Release 4.11 arch/x86/kernel/time.c

Directory: arch/x86/kernel
/*
 *  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%
H. Peter Anvin32.75%111.11%
Anton Blanchard32.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%
Jaswinder Singh Rajput14.35%133.33%
Glauber de Oliveira Costa14.35%133.33%
Total23100.00%3100.00%

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

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner1669.57%150.00%
Andy Shevchenko730.43%150.00%
Total23100.00%2100.00%

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

Contributors

PersonTokensPropCommitsCommitProp
Andi Kleen945.00%120.00%
Thomas Gleixner525.00%240.00%
John Stultz420.00%120.00%
Glauber de Oliveira Costa210.00%120.00%
Total20100.00%5100.00%


static __init void x86_late_time_init(void) { x86_init.timers.timer_init(); tsc_init(); }

Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner19100.00%3100.00%
Total19100.00%3100.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%
Andi Kleen18.33%133.33%
Thomas Gleixner18.33%133.33%
Total12100.00%3100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Thomas Gleixner8629.86%926.47%
Andi Kleen7626.39%823.53%
Glauber de Oliveira Costa4415.28%411.76%
Zwane Mwaikambo3311.46%12.94%
John Stultz144.86%12.94%
Bernhard Walle93.12%12.94%
Andy Shevchenko72.43%12.94%
Anton Blanchard31.04%12.94%
Andrew Lutomirski31.04%25.88%
Paul Gortmaker31.04%12.94%
Ralf Bächle31.04%12.94%
H. Peter Anvin31.04%12.94%
Linus Torvalds20.69%12.94%
Jaswinder Singh Rajput10.35%12.94%
Venkatesh Pallipadi10.35%12.94%
Total288100.00%34100.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.