Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include <stddef.h> | |
| 6 #include <stdint.h> | |
| 7 | |
| 8 #include "base/numerics/safe_conversions.h" | |
| 9 #include "media/filters/ivf_parser.h" | |
| 10 #include "media/filters/vp8_parser.h" | |
| 11 | |
| 12 // Entry point for LibFuzzer. | |
| 13 extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) { | |
| 14 const uint8_t* ivf_payload = nullptr; | |
| 15 media::IvfParser ivf_parser; | |
| 16 media::IvfFileHeader ivf_file_header; | |
| 17 media::IvfFrameHeader ivf_frame_header; | |
| 18 | |
| 19 if (!ivf_parser.Initialize(data, size, &ivf_file_header)) | |
| 20 return 0; | |
| 21 if (ivf_file_header.fourcc != 0x30385056u) // VP80 | |
|
DaleCurtis
2016/03/05 01:30:06
Does this trigger a dcheck otherwise? Seems you co
jrummell
2016/03/07 20:07:28
Since we're testing with random files, I removed t
| |
| 22 return 0; | |
| 23 | |
| 24 // Parse until the end of stream/unsupported stream/error in stream is found. | |
| 25 while (ivf_parser.ParseNextFrame(&ivf_frame_header, &ivf_payload)) { | |
| 26 media::Vp8Parser vp8_parser; | |
| 27 media::Vp8FrameHeader vp8_frame_header; | |
| 28 vp8_parser.ParseFrame(ivf_payload, ivf_frame_header.frame_size, | |
| 29 &vp8_frame_header); | |
| 30 } | |
| 31 | |
| 32 return 0; | |
| 33 } | |
| OLD | NEW |