GitHub Copilot LLM Gateway


A robustness layer for running self-hosted open-source models inside GitHub Copilot Chat — built for the models and servers that don't quite behave.
Do I need this, or is native BYOK enough?
Since VS Code 1.122, VS Code ships a built-in BYOK "Custom Endpoint" provider (Generally Available) that connects any OpenAI-compatible server — vLLM, Ollama, llama.cpp, LM Studio, LocalAI — directly to Copilot chat, agent mode, tools, and MCP, with no extension and no GitHub sign-in required. For most setups that's the simplest path, and you should start there: run Chat: Manage Language Models from the Command Palette and add a Custom Endpoint.
This extension is for the harder cases native BYOK doesn't handle. Native BYOK trusts your endpoint as-is and does no quirk-smoothing — its own docs note that tool-call reliability "depends on your server's tool-call parser." When you're stuck with a specific small or quantized model, or a server you can't reconfigure, that's where this extension earns its place:
| Use native BYOK (built in) when… |
Use this extension when… |
| Your model + server are well-behaved |
Tool calls fail with malformed / truncated JSON |
You can pick the model and configure the server (e.g. --tool-call-parser) |
You're locked to a specific small / quantized model that emits sloppy tool calls |
| You want the simplest, first-party path |
Reasoning models leak <think> blocks into chat or burn their budget mid-thought |
| You want cloud providers too (Anthropic, OpenAI, Gemini…) |
You hit context-length errors and want safe, automatic token budgeting |
If native BYOK already works well for you, you don't need this extension. If your self-hosted small models keep tripping over tool calling, reasoning tags, or context limits, read on.
About
GitHub Copilot LLM Gateway registers as a language model provider inside GitHub Copilot Chat and adds a resilience layer for self-hosted open-source models served over any OpenAI-compatible API (vLLM, Ollama, llama.cpp, LM Studio, LocalAI). Models like Qwen, Llama, and Mistral appear in the Copilot model picker alongside the defaults — but unlike a plain passthrough, the gateway actively repairs the rough edges that small and quantized models produce.
What it does that a plain connection doesn't
| Capability |
What it solves |
| Tool-call JSON repair |
Recovers truncated / malformed tool-call arguments (unclosed strings or braces, trailing commas) instead of aborting the call, and fills in missing required arguments from the tool schema so the call still runs. |
| Streaming tool-call assembly |
Reassembles tool calls from incremental stream deltas across multiple wire formats, tolerating late or missing call IDs. |
| Reasoning / thinking handling |
Routes <think>/<thinking> blocks (and a separate reasoning_content field) into Copilot's thinking UI instead of dumping chain-of-thought into the chat — handling tags split across stream chunks and LM Studio's stray-tag quirk, with a fallback when a model exhausts its budget mid-thought. |
| Safe context budgeting |
Auto-detects the real context window from /v1/models (across vLLM, Ollama, llama.cpp, and LocalAI field names) and shrinks max_tokens conservatively so small servers don't return context-length errors. |
| Tool-call tuning |
Sends a low agent temperature and exposes parallel-tool-call / tool-choice toggles to stabilize tool-call formatting from finicky fine-tuned models. |
| Actionable diagnostics |
Turns raw connection / auth / timeout and tool-parser failures into concrete fixes (remove a stray /v1, drop a Bearer prefix, raise the timeout, disable tool calling). |
It also keeps the familiar benefits of self-hosting: inference stays on your network, there are no per-token fees, and your self-hosted models don't draw down Copilot premium quota.
Privacy note: This extension routes LLM inference to your configured server only — those requests never touch GitHub. It runs inside GitHub Copilot Chat, which is the host application and performs its own network activity (telemetry, and features such as conversation-title generation) that this extension cannot intercept or block. See Privacy & Network Requests for details.
Compatible Inference Servers
- vLLM — High-performance inference (recommended)
- Ollama — Easy local deployment
- llama.cpp — CPU and GPU inference
- Text Generation Inference — Hugging Face's server
- LocalAI — OpenAI API drop-in replacement
- Any OpenAI Chat Completions API-compatible endpoint
Getting Started
Tip: If you only need to connect a well-behaved model, native BYOK is the simpler path. Install this extension when you want the robustness layer for misbehaving small models.
Prerequisites
- VS Code 1.120.0 or later (VS Code's own native BYOK Custom Endpoint requires 1.122+)
- GitHub Copilot extension installed and signed in
- Inference server running with an OpenAI-compatible API
Step 1: Install the Extension
Install GitHub Copilot LLM Gateway from the VS Code Marketplace.
Step 2: Start Your Inference Server
Launch your inference server with tool calling enabled. Here's an example using vLLM:
vllm serve Qwen/Qwen3-8B \
--enable-auto-tool-choice \
--tool-call-parser hermes \
--max-model-len 32768 \
--gpu-memory-utilization 0.95 \
--host 0.0.0.0 \
--port 42069
Verify the server is running:
curl http://localhost:42069/v1/models
- Open VS Code Settings (
Ctrl+, / Cmd+,)
- Search for "Copilot LLM Gateway"
- Set Server URL to your inference server address (e.g.,
http://localhost:8000)
- Configure other settings as needed (token limits, tool calling, etc.)

Note: If the server is unreachable, you'll see an error notification with a quick link to settings:

Step 4: Select Your Model in Copilot Chat
- Open GitHub Copilot Chat (
Ctrl+Alt+I / Cmd+Alt+I)
- Click the model selector dropdown at the bottom of the chat panel
- Click "Manage Models..." to open the model manager

- Select "LLM Gateway" from the provider list
- Enable the models you want to use from your inference server

Step 5: Start Chatting
Your self-hosted models now appear alongside the default Copilot models. Select one and start coding with AI assistance!

The model integrates seamlessly with Copilot's features including:
- Agent mode for autonomous coding tasks
- Tool calling for file operations, terminal commands, and more
- Context awareness with
@workspace and file references
Using your models in the Agents window (Preview)
VS Code 1.120+ adds the Agents window — a separate window for running multiple
agent sessions in parallel. The Agents window and Chat view share the same model
registry, so the gateway's models can be selected as a session's language model there
too.
Because the Agents window runs in its own window, extensions that execute code (like
this one) don't activate there automatically — VS Code only auto-activates extensions
that contribute purely static content (themes, grammars, keybindings). You opt this
extension in with the extensions.supportAgentsWindow setting:
"extensions.supportAgentsWindow": {
"AndrewButson.github-copilot-llm-gateway": true
}
Requirements and notes:
- The extension must be installed in your default VS Code profile.
- After adding the setting, reload/reopen the Agents window so the extension activates.
- Your gateway models then appear in the per-session language model picker, with the
same tool-calling and image capabilities they have in Copilot Chat.
Agents-window extension support is still a VS Code preview and is evolving. If a
gateway model doesn't appear after opting in, confirm the extension is enabled in your
default profile and check the "GitHub Copilot LLM Gateway" output channel.
Configuration
Configure the extension through VS Code Settings (Ctrl+, / Cmd+,) → search "Copilot LLM Gateway".
Connection Settings
| Setting |
Default |
Description |
| Server URL |
http://localhost:8000 |
Base URL of your OpenAI-compatible inference server |
| API Key |
(empty) |
Authentication key if your server requires one |
| Request Timeout |
60000 |
Request timeout in milliseconds |
Model Settings
| Setting |
Default |
Description |
| Default Max Tokens |
262144 |
Fallback context window size (input tokens) used only when the inference server does not report one itself. |
| Default Max Output Tokens |
4096 |
Fallback maximum output tokens used only when the server does not report a context size. |
These settings control how the extension handles agentic features like code editing and file operations.
| Setting |
Default |
Description |
| Enable Tool Calling |
true |
Allow models to use Copilot's tools (file read/write, terminal, etc.) |
| Parallel Tool Calling |
true |
Allow multiple tools to be called simultaneously. Disable if your model struggles with parallel calls. |
| Agent Temperature |
0.0 |
Temperature for tool calling mode. Lower values produce more consistent tool call formatting. |
Tip: If your model outputs tool descriptions as text instead of actually calling tools, try setting Agent Temperature to 0.0 and disabling Parallel Tool Calling.
Diagnostic Settings
| Setting |
Default |
Description |
| Verbose Logging |
false |
When enabled, the full request body (including messages and tool args) is written to the output channel. Keep disabled unless debugging an issue. |
Recommended Models
These models have been tested with good tool calling support:
| Model |
VRAM |
Tool Support |
Best For |
| Qwen/Qwen3-8B |
~16GB |
Excellent |
General coding, 32GB GPU |
| Qwen/Qwen2.5-7B-Instruct |
~14GB |
Excellent |
Balanced performance |
| Qwen/Qwen2.5-14B-Instruct |
~28GB |
Excellent |
Higher quality (48GB GPU) |
| meta-llama/Llama-3.1-8B-Instruct |
~16GB |
Good |
Alternative to Qwen |
Important: Avoid Qwen2.5-Coder models for tool calling—they have known issues with vLLM's tool parser. Use standard Qwen2.5-Instruct or Qwen3 models instead.
vLLM Setup Reference
Installation
pip install vllm
Each model family requires a specific parser:
| Model Family |
Parser |
Example |
| Qwen2.5, Qwen3 |
hermes |
--tool-call-parser hermes |
| Qwen3-Coder |
qwen3_coder |
--tool-call-parser qwen3_coder |
| Llama 3.1/3.2 |
llama3_json |
--tool-call-parser llama3_json |
| Mistral |
mistral |
--tool-call-parser mistral |
VRAM Requirements
Approximate memory for BF16 (full precision) inference:
| Model Size |
Model VRAM |
32K Context Total |
| 7-8B |
~16GB |
~22GB |
| 14B |
~28GB |
~34GB |
| 30B+ |
~60GB |
Requires quantization |
Example Server Commands
Qwen3-8B (Recommended):
vllm serve Qwen/Qwen3-8B \
--enable-auto-tool-choice \
--tool-call-parser hermes \
--max-model-len 32768 \
--gpu-memory-utilization 0.95 \
--host 0.0.0.0 \
--port 42069
Llama 3.1 8B:
vllm serve meta-llama/Llama-3.1-8B-Instruct \
--enable-auto-tool-choice \
--tool-call-parser llama3_json \
--max-model-len 32768 \
--host 0.0.0.0 \
--port 42069
Quantized Model (limited VRAM):
vllm serve Qwen/Qwen2.5-14B-Instruct-AWQ \
--enable-auto-tool-choice \
--tool-call-parser hermes \
--max-model-len 16384 \
--gpu-memory-utilization 0.95 \
--host 0.0.0.0 \
--port 42069
Troubleshooting
Model not appearing in Copilot
- Verify server is running:
curl http://your-server:port/v1/models
- Check Server URL in settings — paste the base URL only, e.g.
http://your-server:port. Do not include a trailing /v1 or a trailing slash; the extension appends /v1/models itself.
- Check API Key — paste the key only. Do not prefix it with
Bearer ; the extension adds that automatically.
- Run command "GitHub Copilot LLM Gateway: Test Server Connection" from the Command Palette.
- If the connection worked earlier but models vanished, run "GitHub Copilot LLM Gateway: Refresh Models" from the Command Palette (or click the status-bar entry).
- Inspect the "GitHub Copilot LLM Gateway" output channel for the exact URL being probed and the server's response.
Model not appearing in the Agents window
The Agents window is a separate window and won't activate this extension automatically.
- Add the opt-in setting (see Using your models in the Agents window):
"extensions.supportAgentsWindow": { "AndrewButson.github-copilot-llm-gateway": true }
- Confirm the extension is installed in your default VS Code profile.
- Reload/reopen the Agents window, then re-check the session's language model picker.
"Model returned empty response"
The model failed to generate output. Try:
- Check tool parser — Ensure
--tool-call-parser matches your model family
- Disable tool calling — Set
github.copilot.llm-gateway.enableToolCalling to false to test basic chat
- Reduce context — Your conversation may exceed the model's limit
The model outputs text like "Using the read_file tool..." instead of actually calling tools.
- Use Qwen3-8B or Qwen2.5-7B-Instruct (avoid Coder variants)
- Set Agent Temperature to
0.0
- Disable Parallel Tool Calling
- Ensure server has
--enable-auto-tool-choice flag
Out of memory errors
- Reduce
--max-model-len (try 8192 or 16384)
- Use a quantized model (AWQ, GPTQ, FP8)
- Choose a smaller model
Commands
Access from the Command Palette (Ctrl+Shift+P / Cmd+Shift+P):
| Command |
Description |
| GitHub Copilot LLM Gateway: Test Server Connection |
Test connectivity and list available models |
| GitHub Copilot LLM Gateway: Refresh Models |
Re-probe the inference server and refresh the picker |
Privacy & Network Requests
This extension is a Language Model provider — it registers alongside GitHub's built-in models and handles inference when you select an LLM Gateway model. Understanding what it does and does not control is important:
What this extension controls
- Chat inference — When you select an LLM Gateway model, all prompts, code snippets, and tool calls are sent exclusively to your configured server. None of this traffic touches GitHub.
What this extension does NOT control
GitHub Copilot Chat is the host application. It performs its own network activity that this extension cannot intercept:
| Request |
Why it happens |
What is sent |
| GitHub authentication |
Copilot Chat requires a GitHub sign-in to activate, even for third-party model providers |
OAuth tokens |
| Conversation title generation |
Copilot Chat sends your first message to GitHub's API to auto-generate a title |
Your prompt text |
| Telemetry |
Copilot collects usage telemetry per its own policies |
Usage metadata |
Reducing exposure
While you cannot fully eliminate GitHub network requests when using Copilot Chat, you can minimise them:
- Set
"telemetry.telemetryLevel": "off" in VS Code settings
- Set
"github.copilot.advanced": { "authProvider": "github" } telemetry-related options as available
Note: We have no control over the Copilot Chat host extension's behaviour. The good news is
that VS Code 1.122 made BYOK work without a GitHub sign-in — the native Custom Endpoint provider
can run chat, tools, and MCP fully air-gapped, so if strict network isolation is your priority that
path is worth evaluating. One gap remains worth requesting upstream on the
VS Code Copilot repository: that conversation
title generation use the selected model provider rather than hardcoded GitHub endpoints.
Support
License
MIT License — see LICENSE for details.
This extension is not affiliated with GitHub or Microsoft. GitHub Copilot is a trademark of GitHub, Inc.