| { |
| "containers": { |
| "cna": { |
| "providerMetadata": { |
| "orgId": "f4215fc3-5b6b-47ff-a258-f7189bd81038" |
| }, |
| "descriptions": [ |
| { |
| "lang": "en", |
| "value": "In the Linux kernel, the following vulnerability has been resolved:\n\nposix-clock: Fix missing timespec64 check in pc_clock_settime()\n\nAs Andrew pointed out, it will make sense that the PTP core\nchecked timespec64 struct's tv_sec and tv_nsec range before calling\nptp->info->settime64().\n\nAs the man manual of clock_settime() said, if tp.tv_sec is negative or\ntp.tv_nsec is outside the range [0..999,999,999], it should return EINVAL,\nwhich include dynamic clocks which handles PTP clock, and the condition is\nconsistent with timespec64_valid(). As Thomas suggested, timespec64_valid()\nonly check the timespec is valid, but not ensure that the time is\nin a valid range, so check it ahead using timespec64_valid_strict()\nin pc_clock_settime() and return -EINVAL if not valid.\n\nThere are some drivers that use tp->tv_sec and tp->tv_nsec directly to\nwrite registers without validity checks and assume that the higher layer\nhas checked it, which is dangerous and will benefit from this, such as\nhclge_ptp_settime(), igb_ptp_settime_i210(), _rcar_gen4_ptp_settime(),\nand some drivers can remove the checks of itself." |
| } |
| ], |
| "affected": [ |
| { |
| "product": "Linux", |
| "vendor": "Linux", |
| "defaultStatus": "unaffected", |
| "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git", |
| "programFiles": [ |
| "kernel/time/posix-clock.c" |
| ], |
| "versions": [ |
| { |
| "version": "0606f422b453f76c31ab2b1bd52943ff06a2dcf2", |
| "lessThan": "29f085345cde24566efb751f39e5d367c381c584", |
| "status": "affected", |
| "versionType": "git" |
| }, |
| { |
| "version": "0606f422b453f76c31ab2b1bd52943ff06a2dcf2", |
| "lessThan": "e0c966bd3e31911b57ef76cec4c5796ebd88e512", |
| "status": "affected", |
| "versionType": "git" |
| }, |
| { |
| "version": "0606f422b453f76c31ab2b1bd52943ff06a2dcf2", |
| "lessThan": "673a1c5a2998acbd429d6286e6cad10f17f4f073", |
| "status": "affected", |
| "versionType": "git" |
| }, |
| { |
| "version": "0606f422b453f76c31ab2b1bd52943ff06a2dcf2", |
| "lessThan": "c8789fbe2bbf75845e45302cba6ffa44e1884d01", |
| "status": "affected", |
| "versionType": "git" |
| }, |
| { |
| "version": "0606f422b453f76c31ab2b1bd52943ff06a2dcf2", |
| "lessThan": "27abbde44b6e71ee3891de13e1a228aa7ce95bfe", |
| "status": "affected", |
| "versionType": "git" |
| }, |
| { |
| "version": "0606f422b453f76c31ab2b1bd52943ff06a2dcf2", |
| "lessThan": "a3f169e398215e71361774d13bf91a0101283ac2", |
| "status": "affected", |
| "versionType": "git" |
| }, |
| { |
| "version": "0606f422b453f76c31ab2b1bd52943ff06a2dcf2", |
| "lessThan": "1ff7247101af723731ea42ed565d54fb8f341264", |
| "status": "affected", |
| "versionType": "git" |
| }, |
| { |
| "version": "0606f422b453f76c31ab2b1bd52943ff06a2dcf2", |
| "lessThan": "d8794ac20a299b647ba9958f6d657051fc51a540", |
| "status": "affected", |
| "versionType": "git" |
| } |
| ] |
| }, |
| { |
| "product": "Linux", |
| "vendor": "Linux", |
| "defaultStatus": "affected", |
| "repo": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git", |
| "programFiles": [ |
| "kernel/time/posix-clock.c" |
| ], |
| "versions": [ |
| { |
| "version": "2.6.39", |
| "status": "affected" |
| }, |
| { |
| "version": "0", |
| "lessThan": "2.6.39", |
| "status": "unaffected", |
| "versionType": "semver" |
| }, |
| { |
| "version": "4.19.323", |
| "lessThanOrEqual": "4.19.*", |
| "status": "unaffected", |
| "versionType": "semver" |
| }, |
| { |
| "version": "5.4.285", |
| "lessThanOrEqual": "5.4.*", |
| "status": "unaffected", |
| "versionType": "semver" |
| }, |
| { |
| "version": "5.10.228", |
| "lessThanOrEqual": "5.10.*", |
| "status": "unaffected", |
| "versionType": "semver" |
| }, |
| { |
| "version": "5.15.169", |
| "lessThanOrEqual": "5.15.*", |
| "status": "unaffected", |
| "versionType": "semver" |
| }, |
| { |
| "version": "6.1.114", |
| "lessThanOrEqual": "6.1.*", |
| "status": "unaffected", |
| "versionType": "semver" |
| }, |
| { |
| "version": "6.6.58", |
| "lessThanOrEqual": "6.6.*", |
| "status": "unaffected", |
| "versionType": "semver" |
| }, |
| { |
| "version": "6.11.5", |
| "lessThanOrEqual": "6.11.*", |
| "status": "unaffected", |
| "versionType": "semver" |
| }, |
| { |
| "version": "6.12", |
| "lessThanOrEqual": "*", |
| "status": "unaffected", |
| "versionType": "original_commit_for_fix" |
| } |
| ] |
| } |
| ], |
| "cpeApplicability": [ |
| { |
| "nodes": [ |
| { |
| "operator": "OR", |
| "negate": false, |
| "cpeMatch": [ |
| { |
| "vulnerable": true, |
| "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*", |
| "versionStartIncluding": "2.6.39", |
| "versionEndExcluding": "4.19.323" |
| }, |
| { |
| "vulnerable": true, |
| "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*", |
| "versionStartIncluding": "2.6.39", |
| "versionEndExcluding": "5.4.285" |
| }, |
| { |
| "vulnerable": true, |
| "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*", |
| "versionStartIncluding": "2.6.39", |
| "versionEndExcluding": "5.10.228" |
| }, |
| { |
| "vulnerable": true, |
| "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*", |
| "versionStartIncluding": "2.6.39", |
| "versionEndExcluding": "5.15.169" |
| }, |
| { |
| "vulnerable": true, |
| "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*", |
| "versionStartIncluding": "2.6.39", |
| "versionEndExcluding": "6.1.114" |
| }, |
| { |
| "vulnerable": true, |
| "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*", |
| "versionStartIncluding": "2.6.39", |
| "versionEndExcluding": "6.6.58" |
| }, |
| { |
| "vulnerable": true, |
| "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*", |
| "versionStartIncluding": "2.6.39", |
| "versionEndExcluding": "6.11.5" |
| }, |
| { |
| "vulnerable": true, |
| "criteria": "cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:*", |
| "versionStartIncluding": "2.6.39", |
| "versionEndExcluding": "6.12" |
| } |
| ] |
| } |
| ] |
| } |
| ], |
| "references": [ |
| { |
| "url": "https://git.kernel.org/stable/c/29f085345cde24566efb751f39e5d367c381c584" |
| }, |
| { |
| "url": "https://git.kernel.org/stable/c/e0c966bd3e31911b57ef76cec4c5796ebd88e512" |
| }, |
| { |
| "url": "https://git.kernel.org/stable/c/673a1c5a2998acbd429d6286e6cad10f17f4f073" |
| }, |
| { |
| "url": "https://git.kernel.org/stable/c/c8789fbe2bbf75845e45302cba6ffa44e1884d01" |
| }, |
| { |
| "url": "https://git.kernel.org/stable/c/27abbde44b6e71ee3891de13e1a228aa7ce95bfe" |
| }, |
| { |
| "url": "https://git.kernel.org/stable/c/a3f169e398215e71361774d13bf91a0101283ac2" |
| }, |
| { |
| "url": "https://git.kernel.org/stable/c/1ff7247101af723731ea42ed565d54fb8f341264" |
| }, |
| { |
| "url": "https://git.kernel.org/stable/c/d8794ac20a299b647ba9958f6d657051fc51a540" |
| } |
| ], |
| "title": "posix-clock: Fix missing timespec64 check in pc_clock_settime()", |
| "x_generator": { |
| "engine": "bippy-1.2.0" |
| } |
| } |
| }, |
| "cveMetadata": { |
| "assignerOrgId": "f4215fc3-5b6b-47ff-a258-f7189bd81038", |
| "cveID": "CVE-2024-50195", |
| "requesterUserId": "gregkh@kernel.org", |
| "serial": "1", |
| "state": "PUBLISHED" |
| }, |
| "dataType": "CVE_RECORD", |
| "dataVersion": "5.0" |
| } |