cregit-Linux how code gets into the kernel

Release 4.11 drivers/xen/cpu_hotplug.c

Directory: drivers/xen

#define pr_fmt(fmt) "xen:" KBUILD_MODNAME ": " fmt

#include <linux/notifier.h>

#include <xen/xen.h>
#include <xen/xenbus.h>

#include <asm/xen/hypervisor.h>
#include <asm/cpu.h>


static void enable_hotplug_cpu(int cpu) { if (!cpu_present(cpu)) xen_arch_register_cpu(cpu); set_cpu_present(cpu, true); }

Contributors

PersonTokensPropCommitsCommitProp
Alex Nixon2689.66%133.33%
Rusty Russell26.90%133.33%
Stefano Stabellini13.45%133.33%
Total29100.00%3100.00%


static void disable_hotplug_cpu(int cpu) { if (cpu_online(cpu)) { lock_device_hotplug(); device_offline(get_cpu_device(cpu)); unlock_device_hotplug(); } if (cpu_present(cpu)) xen_arch_unregister_cpu(cpu); set_cpu_present(cpu, false); }

Contributors

PersonTokensPropCommitsCommitProp
Alex Nixon2549.02%125.00%
Stefano Stabellini2447.06%250.00%
Rusty Russell23.92%125.00%
Total51100.00%4100.00%


static int vcpu_online(unsigned int cpu) { int err; char dir[16], state[16]; sprintf(dir, "cpu/%u", cpu); err = xenbus_scanf(XBT_NIL, dir, "availability", "%15s", state); if (err != 1) { if (!xen_initial_domain()) pr_err("Unable to read cpu state\n"); return err; } if (strcmp(state, "online") == 0) return 1; else if (strcmp(state, "offline") == 0) return 0; pr_err("unknown state(%s) on CPU%d\n", state, cpu); return -EINVAL; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Nixon7667.86%120.00%
Ian Campbell2320.54%120.00%
Konrad Rzeszutek Wilk65.36%120.00%
Joe Perches43.57%120.00%
Jan Beulich32.68%120.00%
Total112100.00%5100.00%


static void vcpu_hotplug(unsigned int cpu) { if (!cpu_possible(cpu)) return; switch (vcpu_online(cpu)) { case 1: enable_hotplug_cpu(cpu); break; case 0: disable_hotplug_cpu(cpu); break; default: break; } }

Contributors

PersonTokensPropCommitsCommitProp
Ian Campbell4083.33%150.00%
Alex Nixon816.67%150.00%
Total48100.00%2100.00%


static void handle_vcpu_hotplug_event(struct xenbus_watch *watch, const char *path, const char *token) { unsigned int cpu; char *cpustr; cpustr = strstr(path, "cpu/"); if (cpustr != NULL) { sscanf(cpustr, "cpu/%u", &cpu); vcpu_hotplug(cpu); } }

Contributors

PersonTokensPropCommitsCommitProp
Alex Nixon5590.16%150.00%
Juergen Gross69.84%150.00%
Total61100.00%2100.00%


static int setup_cpu_watcher(struct notifier_block *notifier, unsigned long event, void *data) { int cpu; static struct xenbus_watch cpu_watch = { .node = "cpu", .callback = handle_vcpu_hotplug_event}; (void)register_xenbus_watch(&cpu_watch); for_each_possible_cpu(cpu) { if (vcpu_online(cpu) == 0) { (void)cpu_down(cpu); set_cpu_present(cpu, false); } } return NOTIFY_DONE; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Nixon4857.83%133.33%
Ian Campbell3339.76%133.33%
Rusty Russell22.41%133.33%
Total83100.00%3100.00%


static int __init setup_vcpu_hotplug_event(void) { static struct notifier_block xsn_cpu = { .notifier_call = setup_cpu_watcher }; #ifdef CONFIG_X86 if (!xen_pv_domain() && !xen_pvh_domain()) #else if (!xen_domain()) #endif return -ENODEV; register_xenstore_notifier(&xsn_cpu); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Nixon4070.18%250.00%
Stefano Stabellini1322.81%125.00%
Boris Ostrovsky47.02%125.00%
Total57100.00%4100.00%

arch_initcall(setup_vcpu_hotplug_event);

Overall Contributors

PersonTokensPropCommitsCommitProp
Alex Nixon29462.82%214.29%
Ian Campbell9620.51%17.14%
Stefano Stabellini388.12%214.29%
Joe Perches112.35%17.14%
Konrad Rzeszutek Wilk61.28%17.14%
Juergen Gross61.28%17.14%
Rusty Russell61.28%214.29%
Boris Ostrovsky40.85%17.14%
Jan Beulich30.64%17.14%
Jeremy Fitzhardinge30.64%17.14%
Al Viro10.21%17.14%
Total468100.00%14100.00%
Directory: drivers/xen
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.