agent:
  repo_url: https://git.ffmpeg.org/ffmpeg.git
  repo_name: ffmpeg
  patch_gen_llm: o1
  num_patches: 1
  max_analysis_steps: 10
  logs_dir: logs
  work_dir: workdir
  langs: C,C++,Python,Asm,Cuda

prompts:
  preamble: |- 
    You are an expert FFmpeg developer specializing in bug analysis and repair. Your deep understanding spans all of FFmpeg's internals, including media codecs, demuxers, filters, and protocols. You have extensive experience analyzing crash reports and fuzzer-generated bug reports to identify and fix complex bugs in media processing code.
    Your task is to analyze a bug in the FFmpeg repository, explore the repository's code to figure out the root cause of the bug, and gather enough context to propose a fix for the bug. You will be given a crash report generated by a fuzzer. The crash report contains a stack trace and potentially additional diagnostic information like register values, memory dumps, or sanitizer output. Note that you will not have access to the fuzz test case that triggered the crash or any external media files - you must rely solely on analyzing the FFmpeg source code itself. You also will not have access to any system library files. Your task is to understand the root cause by examining the FFmpeg source code and propose fixes by modifying FFmpeg's implementation, not the test case."""
  analysis_examples: |-
    Example 1 (Exploring the code):

    <thoughts>
    Looking at the crash report, I see a NULL pointer dereference in av_fast_padded_malloc() when handling a buffer allocation. The crash occurs when attempting to dereference a null pointer in the memset call. This suggests there may be an issue with checking for NULL after memory allocation. I should examine similar memory allocation patterns in the codebase.

    I'll look at the memory allocation code, search for similar patterns, and check the commit history for related bug fixes.
    </thoughts>

    <actions> 
    search_definition("libavcodec/utils.c", "av_fast_padded_malloc")
    search_code("av_fast_.*malloc")
    search_code("av_malloc")
    search_commits("null.*check|av_fast.*malloc") 
    </actions>

    <memory>
    - Crash occurs in av_fast_padded_malloc during memset
    - Need to understand memory allocation and NULL checks
    - Similar allocation patterns may reveal proper handling
    </memory>

    Example 2 (rejecting a justification):

    <thoughts>
    I see that av_fast_padded_malloc() may dereference a NULL pointer - it needs proper validation. However, I need more context about the allocation patterns and buffer management, including how av_fast_mallocz works and how other parts handle allocation failures. I should also check past commits for similar issues. Since I don't have complete understanding yet, I will continue exploring.
    </thoughts>

    <actions>
    search_definition("libavutil/mem.c", "av_fast_mallocz")
    search_definition("AVBuffer") 
    search_commits("av_fast.*malloc|null.*check")
    search_code("av_(fast_)?malloc.*\\(")
    </actions>

    Example 3 (taking `done` action after exploring):

    <thoughts>
    After examining the code, I understand that av_fast_padded_malloc() is crashing because it doesn't properly validate the pointer after allocation. The function tries to write to memory without checking if av_fast_mallocz succeeded. I've found examples of correct NULL checking patterns in other allocation code, and commits showing this was addressed in other parts of FFmpeg. The commit history shows similar NULL check patches being added to improve robustness. I also understand how av_fast_mallocz works - it can return NULL on failure. Therefore, I know what's missing (NULL check) and where to add it (before using memset).

    This justification is complete because I understand both the immediate cause (missing NULL check) and the wider context (FFmpeg's memory allocation patterns). I know what change to make and why it will fix the issue. I will take the done action.
    </thoughts>

    <actions>
    done
    <justification>
    The crash occurs because av_fast_padded_malloc doesn't properly check for NULL after calling av_fast_mallocz. Memory allocation failure handling is critical in FFmpeg. I have found the correct pattern in other parts of the codebase - they all check pointers after allocation before using them. Past commits show this was a systematic issue that was fixed across the codebase by adding NULL checks, but this function was overlooked. Similar commits indicate this is a well-understood fix pattern in FFmpeg. I know what change to make - add a NULL check before the memset call. I've also verified this matches FFmpeg's allocation patterns by examining the av_fast_mallocz implementation and similar functions. The context shows this is a clear case of missing NULL validation, and I have all the information needed to fix it properly.
    </justification>
    </actions>

    <memory>
    - av_fast_padded_malloc crashes due to missing NULL check
    - Memory allocation failure handling required 
    - Other allocation code follows proper NULL validation patterns
    - Past commits show systematic addition of NULL checks
    - Similar patches landed for other allocation functions 
    - Bug fix requires adding NULL check before memset
    </memory>
  patch_gen_examples: |-
    <thoughts>
    After examining the code, I see that av_fast_padded_malloc() is calling av_fast_mallocz() but not properly validating the return value before using memset(). Since av_fast_mallocz() can return NULL on allocation failure, this leads to a NULL pointer dereference. Based on FFmpeg's memory handling patterns seen in similar functions like av_malloc() and av_realloc(), we need to add proper NULL pointer validation.
    </thoughts>

    <hypothesis>
    The segmentation fault occurs because av_fast_padded_malloc() isn't properly checking for allocation failure. This happens in the following sequence:

    1. av_fast_mallocz() is called and returns NULL due to allocation failure
    2. The code proceeds to call memset() without checking the pointer
    3. The NULL pointer dereference in memset() causes a crash 

    According to FFmpeg's memory allocation patterns and past fixes, all allocation calls must be checked for NULL return values before dereferencing. The code should validate the pointer returned by av_fast_mallocz() before using it.
    </hypothesis>

    <patch>
    <symbol file="libavcodec/utils.c" name="av_fast_padded_malloc" start="138">
    void av_fast_padded_malloc(void *ptr, unsigned int *size, size_t min_size)
    {
        void **p = ptr;
        if (min_size > SIZE_MAX - AV_INPUT_BUFFER_PADDING_SIZE) {
            *size = 0;
            av_freep(p);
            return;
        }
        if (!*size)
            *size = min_size;
        *p = av_fast_mallocz(*p, size, min_size + AV_INPUT_BUFFER_PADDING_SIZE);
        if (!*p) {
            *size = 0;
            return;
        }
        memset((uint8_t *)*p + min_size, 0, AV_INPUT_BUFFER_PADDING_SIZE);
    }
    </symbol>
    </patch>