nixpkgs/pkgs/os-specific/linux/mcelog/default.nix
R. RyanTM 5427a1a383 mcelog: 157 -> 158 (#41112)
Semi-automatic update generated by https://github.com/ryantm/nixpkgs-update tools.

This update was made based on information from https://repology.org/metapackage/mcelog/versions.

These checks were done:

- built on NixOS
- /nix/store/1fqizqnwbm6d0m3bfhf07ifi974lf462-mcelog-158/bin/mcelog passed the binary check.
- 1 of 1 passed binary check by having a zero exit code.
- 1 of 1 passed binary check by having the new version present in output.
- found 158 with grep in /nix/store/1fqizqnwbm6d0m3bfhf07ifi974lf462-mcelog-158
- directory tree listing: https://gist.github.com/9d64a5e08433a1d54e003d1331d5dcb4
- du listing: https://gist.github.com/58a6326ee54553f647aebedff6e4e46d
2018-05-28 21:07:28 +02:00

52 lines
1.6 KiB
Nix

{ stdenv, fetchFromGitHub, utillinux }:
stdenv.mkDerivation rec {
name = "mcelog-${version}";
version = "158";
src = fetchFromGitHub {
owner = "andikleen";
repo = "mcelog";
rev = "v${version}";
sha256 = "0hiyj626fv4awzqgf4wnxjkr68cfcllqpibw0ncnpkvk9rn96rqp";
};
postPatch = ''
for i in mcelog.conf paths.h; do
substituteInPlace $i --replace /etc $out/etc
done
touch mcelog.conf.5 # avoid regeneration requiring Python
substituteInPlace Makefile --replace '"unknown"' '"${version}"'
for i in triggers/*; do
substituteInPlace $i --replace 'logger' '${utillinux}/bin/logger'
done
'';
enableParallelBuilding = true;
installFlags = [ "DESTDIR=$(out)" "prefix=" "DOCDIR=/share/doc" ];
postInstall = ''
mkdir -p $out/lib/systemd/system
substitute mcelog.service $out/lib/systemd/system/mcelog.service \
--replace /usr/sbin $out/bin
'';
meta = with stdenv.lib; {
description = "Log x86 machine checks: memory, IO, and CPU hardware errors";
longDescription = ''
The mcelog daemon accounts memory and some other errors in various ways
on modern x86 Linux systems. The daemon can be queried and/or execute
triggers when configurable error thresholds are exceeded. This is used to
implement a range of automatic predictive failure analysis algorithms,
including bad page offlining and automatic cache error handling. All
errors are logged to /var/log/mcelog or syslog or the journal.
'';
homepage = http://mcelog.org/;
license = licenses.gpl2;
platforms = platforms.linux;
};
}