Summary: | [cpuctl] [patch] Memory leak/corruption in cpuctl pseudo-driver and more | ||||||
---|---|---|---|---|---|---|---|
Product: | Base System | Reporter: | John Clark <clarkjc> | ||||
Component: | kern | Assignee: | freebsd-bugs (Nobody) <bugs> | ||||
Status: | Closed FIXED | ||||||
Severity: | Affects Some People | CC: | gonzo, kib, op, samflanker, sblachmann | ||||
Priority: | Normal | ||||||
Version: | 10.1-RELEASE | ||||||
Hardware: | Any | ||||||
OS: | Any | ||||||
Attachments: |
|
Description
John Clark
2013-06-12 21:40:00 UTC
P.S. Oops, it looks like I reversed my name and email address in the web submission form. I should have set up sendmail and used send-pr... - John # uname -a FreeBSD anonymous.orb 10.1-RELEASE FreeBSD 10.1-RELEASE #0 r274401: Tue Nov 11 21:02:49 UTC 2014 root@releng1.nyi.freebsd.org:/usr/obj/usr/src/sys/GENERIC amd64 # dmesg | grep ^CPU CPU: Intel(R) Xeon(R) CPU E3-1270 v3 @ 3.50GHz (3491.99-MHz K8-class CPU) # /usr/sbin/cpucontrol -u -d /usr/local/share/cpucontrol /dev/cpuctl1 /usr/local/share/cpucontrol/m32306c3_0000001c.fw: updating cpu /dev/cpuctl1 from rev 0x9 to rev 0x1c... failed. cpucontrol: ioctl(): Invalid argument /usr/local/share/cpucontrol/06-3c-03: updating cpu /dev/cpuctl1 from rev 0x9 to rev 0x16... failed. cpucontrol: ioctl(): Invalid argument /usr/local/share/cpucontrol/m32306c3_0000001c.fw: updating cpu /dev/cpuctl1 from rev 0x9 to rev 0x1c... failed. cpucontrol: ioctl(): Invalid argument /usr/local/share/cpucontrol/06-3c-03: updating cpu /dev/cpuctl1 from rev 0x9 to rev 0x16... failed. cpucontrol: ioctl(): Invalid argument # grep "UCODE_SIZE_MAX" /usr/src/sys/dev/cpuctl/cpuctl.c | head -1 #define UCODE_SIZE_MAX (16 * 1024) # patch -p0 < file.patch Hmm... Looks like a unified diff to me... The text leading up to this was: -------------------------- |--- sys/dev/cpuctl/cpuctl.c.orig 2012-12-03 19:52:24.000000000 -0500 |+++ sys/dev/cpuctl/cpuctl.c 2013-06-12 13:15:20.000000000 -0400 -------------------------- Patching file sys/dev/cpuctl/cpuctl.c using Plan A... Hunk #1 failed at 63. Hunk #2 failed at 295. Hunk #3 failed at 314. Hunk #4 succeeded at 416 with fuzz 2 (offset 70 lines). Hunk #5 failed at 479. Hunk #6 failed at 498. Hunk #7 failed at 546. 6 out of 7 hunks failed--saving rejects to sys/dev/cpuctl/cpuctl.c.rej done John, please modify patch for 10.1-RELEASE A commit references this bug: Author: kib Date: Sat Dec 20 16:40:50 UTC 2014 New revision: 275960 URL: https://svnweb.freebsd.org/changeset/base/275960 Log: Increase allowed size of the microcode blob to 32KB. Some Intel CPU's updates weight 28KB. PR: 179523 MFC after: 1 week Changes: head/sys/dev/cpuctl/cpuctl.c To originators/assignees of this PR: A commit to the tree references this PR, however the PR is still in a non-closed state. Please review this PR and close as appropriate, or if closing the PR requires a merge to stable/10, please let re@ know as soon as possible. Thank you. Glen The current version of cpuctl.c contains this definition #define UCODE_SIZE_MAX (4 * 1024 * 1024) which should be sufficent for some years, as the latest Intel microcode release's maximum filesize is close to 100kB. So I think this PR can be closed. |