U.S. flag   An official website of the United States government
Dot gov

Official websites use .gov
A .gov website belongs to an official government organization in the United States.

Https

Secure .gov websites use HTTPS
A lock (Dot gov) or https:// means you've safely connected to the .gov website. Share sensitive information only on official, secure websites.

Vulnerability Change Records for CVE-2024-27066

Change History

New CVE Received from kernel.org 5/01/2024 9:15:50 AM

Action Type Old Value New Value
Added Description

								
							
							
						
In the Linux kernel, the following vulnerability has been resolved:

virtio: packed: fix unmap leak for indirect desc table

When use_dma_api and premapped are true, then the do_unmap is false.

Because the do_unmap is false, vring_unmap_extra_packed is not called by
detach_buf_packed.

  if (unlikely(vq->do_unmap)) {
                curr = id;
                for (i = 0; i < state->num; i++) {
                        vring_unmap_extra_packed(vq,
                                                 &vq->packed.desc_extra[curr]);
                        curr = vq->packed.desc_extra[curr].next;
                }
  }

So the indirect desc table is not unmapped. This causes the unmap leak.

So here, we check vq->use_dma_api instead. Synchronously, dma info is
updated based on use_dma_api judgment

This bug does not occur, because no driver use the premapped with
indirect.
Added Reference

								
							
							
						
kernel.org https://git.kernel.org/stable/c/51bacd9d29bf98c3ebc65e4a0477bb86306b4140 [No types assigned]
Added Reference

								
							
							
						
kernel.org https://git.kernel.org/stable/c/75450ff8c6fe8755bf5b139b238eaf9739cfd64e [No types assigned]
Added Reference

								
							
							
						
kernel.org https://git.kernel.org/stable/c/d5c0ed17fea60cca9bc3bf1278b49ba79242bbcd [No types assigned]
Added Reference

								
							
							
						
kernel.org https://git.kernel.org/stable/c/e142169aca5546ae6619c39a575cda8105362100 [No types assigned]