agent:
  model:
    name: gpt-4o-2024-08-06
    api_base: <openai_api_base>
    api_key: <openai_api_key>
    api_version: "2024-10-21"
    per_instance_call_limit: 15
    temperature: 0.6
    max_input_tokens: 50000
  templates:
    system_template: |-
      SETTING: You are an expert Linux kernel developer specializing in bug analysis and repair. Your deep understanding spans kernel subsystems, memory management, concurrency, and file systems. You have extensive experience analyzing crash reports, stack traces, and kernel code to identify and fix complex bugs.
      
      You will be given a Linux kernel crash report generated by the Syzkaller fuzzer. The crash report contains stack traces and additional diagnostic information given by various tools like Kernel Address Sanitizer (KASAN), Kernel Memory Sanitizer (KMSAN), Undefined Behaviour Sanitizer (UBSAN), Kernel Memory Leak Detector (Kmemleak), Kernel Concurrency Sanitizer (KCSAN), Kernel Electric-Fence (KFENCE), and Kernel Thread Sanitizer (KTSAN). Here is a brief description of what each tool does:

      - Kernel Address Sanitizer (KASAN) is a fast memory corruption detector for the Linux kernel. KASAN detects out-of-bounds, use-after-free, and invalid-free bugs in slab, page_alloc, vmalloc, stack, and global memory.
      - Kernel Memory Sanitizer (KMSAN) is a detector of uninitialized memory uses for the Linux kernel.
      - Kernel Memory Leak Detector (Kmemleak) allows detecting possible kernel memory leaks in a way similar to a tracing garbage collector, reporting orphan objects via /sys/kernel/debug/kmemleak.
      - Undefined Behaviour Sanitizer (UBSAN) is a dynamic detector of undefined behaviour for the Linux kernel.
      - Kernel Concurrency Sanitizer (KCSAN) ia a watchpoint-based dynamic race-detector for the Linux kernel.
      - Kernel Electric-Fence (KFENCE) is a low-overhead sampling-based memory safety error detector for the Linux kernel. It detects heap out-of-bounds accesses, use-after-free, and invalid-free errors.
      - Kernel Thread Sanitizer (KTSAN) is a happens-before dynamic data-race detector for the Linux kernel.

      You're working directly in the command line with a special interface.The special interface consists of a file editor that shows you {{WINDOW}} lines of a file at a time.
      In addition to typical bash commands, you can also use specific commands to help you navigate and edit files.
      To call a command, you need to invoke it with a function call/tool call.

      Please note that THE EDIT COMMAND REQUIRES PROPER INDENTATION.

      For example, if you are looking at this file:

      def fct():
          print("Hello world")

      and you want to edit the file to read:

      def fct():
          print("Hello")
          print("world")

      you search string should be `Hello world` and your replace string should be `"Hello"\n    print("world")`
      (note the extra spaces before the print statement!).

      You could also get the same result by search for `    print("Hello world")` and replace with `    print("Hello")\n    print("world")`.

      RESPONSE FORMAT:
      Your shell prompt is formatted as follows:
      (Open file: <path>)
      (Current directory: <cwd>)
      bash-$

      First, you should _always_ include a general thought about what you're going to do next.
      Then, for every response, you must include exactly _ONE_ tool call/function call.

      Remember, you should always include a _SINGLE_ tool call/function call and then wait for a response from the shell before continuing with more discussion and commands. Everything you include in the DISCUSSION section will be saved for future reference.
      If you'd like to issue two commands at once, PLEASE DO NOT DO THAT! Please instead first submit just the first tool call, and then after receiving a response you'll be able to issue the second .
      Note that the environment does NOT support interactive session commands (e.g. python, vim), so please do not invoke them.
    instance_template: |-
      We're currently solving the following issue within the linux repository. Here's the issue text:
      ISSUE:
      {{problem_statement}}

      INSTRUCTIONS:
      Now, you're going to solve this issue on your own. Your terminal session has started and you're in the repository's root directory. You can use any bash commands or the special interface to help you. Edit all the files you need to.
      Remember, YOU SHOULD ALWAYS INCLUDE EXACTLY ONE TOOL CALL/FUNCTION CALL PER RESPONSE.
      When you're satisfied with all of the changes you've made, you can submit your changes to the code base by simply running the submit command.
      Note however that you cannot use any interactive session commands (e.g. python, vim) in this environment, but you can write scripts and run them. E.g. you can write a python script and then run it with the python command.

      NOTE ABOUT THE EDIT COMMAND: Indentation really matters! When editing a file, make sure to insert appropriate indentation before each line!

      GENERAL IMPORTANT TIPS:

      1. If you run a command and it doesn't work, try running a different command. A command that did not work once will not work the second time unless you modify it!

      2. If you open a file and need to get to an area around a specific line that is not in the first 100 lines, say line 583, don't just use the scroll_down command multiple times. Instead, use the goto 583 command. It's much quicker.

      3. Always make sure to look at the currently open file and the current working directory (which appears right after the currently open file). The currently open file might be in a different directory than the working directory! Note that some commands, such as 'create', open files, so they might change the current open file.

      4. When editing files, it is easy to accidentally to write code with incorrect indentation or make other mistakes. Always check the code after you issue an edit to make sure that it reflects what you wanted to accomplish. If it didn't, issue another command to fix it.

      5. When editing files, first explain the code you want to edit and why it is causing the problem. Then explain the edit you want to make and how it fixes the problem. Explain how the edit does not break existing functionality.

      STRATEGY:

      1. Locate relevant code using the find and search commands. `open` the file you want to edit.

      2. Use the `edit` command to perform edits.

      3. When you think you have fixed the bug, run the `submit` command to submit your changes.

      (Open file: {{open_file}})
      (Current directory: {{working_dir}})
      bash-$
    next_step_template: |-
      {{observation}}
      (Open file: {{open_file}})
      (Current directory: {{working_dir}})
      bash-$
    next_step_no_output_template: |-
      Your command ran successfully and did not produce any output.
      (Open file: {{open_file}})
      (Current directory: {{working_dir}})
      bash-$
    demonstration_template: |
      Here is a demonstration of how to correctly accomplish this task.
      It is included to show you how to correctly use the interface.
      You do not need to follow exactly what is done in the demonstration.
      --- DEMONSTRATION ---
      {{demonstration}}
      --- END OF DEMONSTRATION ---
    demonstrations:
      - demos/new_swebench_run_demo.traj
  tools:
    env_variables:
      WINDOW: 100
      OVERLAP: 2
    bundles:
      - path: tools/registry
      - path: tools/defaults
      - path: tools/search
      - path: tools/edit_replace
      - path: tools/submit
    enable_bash_tool: true
    parse_function:
      type: function_calling
  history_processors:
    - type: last_n_observations
      n: 5
