/* Copyright (C) 20014 Intel Corporation Author: Rui Wang Handle all other unknown error requests. mcelog is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; version 2. mcelog is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should find a copy of v2 of the GNU General Public License somewhere on your Linux system. */ #define _GNU_SOURCE 1 #include #include #include #include #include #include "memutil.h" #include "mcelog.h" #include "config.h" #include "trigger.h" #include "unknown.h" static char *unknown_trigger; enum { MAX_ENV = 20, }; void unknown_setup(void) { unknown_trigger = config_string("socket", "unknown-threshold-trigger"); if (unknown_trigger && trigger_check(unknown_trigger) < 0) { SYSERRprintf("Cannot access unknown threshold trigger `%s'", unknown_trigger); exit(1); } } void run_unknown_trigger(int socket, int cpu, struct mce *log) { int ei = 0; char *env[MAX_ENV]; int i; char *msg; char *location; if (!unknown_trigger) return; if (socket >= 0) xasprintf(&location, "CPU %d on socket %d", cpu, socket); else xasprintf(&location, "CPU %d", cpu); xasprintf(&msg, "%s received unknown error", location); xasprintf(&env[ei++], "LOCATION=%s", location); free(location); location = NULL; if (socket >= 0) xasprintf(&env[ei++], "SOCKETID=%d", socket); xasprintf(&env[ei++], "MESSAGE=%s", msg); xasprintf(&env[ei++], "CPU=%d", cpu); xasprintf(&env[ei++], "STATUS=%llx", log->status); xasprintf(&env[ei++], "MISC=%llx", log->misc); xasprintf(&env[ei++], "ADDR=%llx", log->addr); xasprintf(&env[ei++], "MCGSTATUS=%llx", log->mcgstatus); xasprintf(&env[ei++], "MCGCAP=%llx", log->mcgcap); env[ei] = NULL; assert(ei < MAX_ENV); run_trigger(unknown_trigger, NULL, env, false, "unknown"); for (i = 0; i < ei; i++) { free(env[i]); env[i] = NULL; } free(msg); msg = NULL; }