mirror of
				https://git.suyu.dev/suyu/suyu
				synced 2025-11-03 16:39:01 -06:00 
			
		
		
		
	nvhost_gpu: Added checks to ensure we don't read past the end of the entries when handling a GPU command list.
This commit is contained in:
		@@ -132,9 +132,12 @@ u32 nvhost_gpu::SubmitGPFIFO(const std::vector<u8>& input, std::vector<u8>& outp
 | 
			
		||||
    LOG_WARNING(Service_NVDRV, "(STUBBED) called, gpfifo={:X}, num_entries={:X}, flags={:X}",
 | 
			
		||||
                params.address, params.num_entries, params.flags);
 | 
			
		||||
 | 
			
		||||
    auto entries = std::vector<IoctlGpfifoEntry>();
 | 
			
		||||
    entries.resize(params.num_entries);
 | 
			
		||||
    std::memcpy(&entries[0], &input.data()[sizeof(IoctlSubmitGpfifo)],
 | 
			
		||||
    ASSERT_MSG(input.size() ==
 | 
			
		||||
                   sizeof(IoctlSubmitGpfifo) + params.num_entries * sizeof(IoctlGpfifoEntry),
 | 
			
		||||
               "Incorrect input size");
 | 
			
		||||
 | 
			
		||||
    std::vector<IoctlGpfifoEntry> entries(params.num_entries);
 | 
			
		||||
    std::memcpy(entries.data(), &input[sizeof(IoctlSubmitGpfifo)],
 | 
			
		||||
                params.num_entries * sizeof(IoctlGpfifoEntry));
 | 
			
		||||
    for (auto entry : entries) {
 | 
			
		||||
        Tegra::GPUVAddr va_addr = entry.Address();
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user