Why is there a `remotes/origin/HEAD -> origin/master` entry in my `git branch -l -a` output?

No, no need to clean up: it is the symbolic branch referenced by your remote repo.
When you clone your repo, you will be by default on the branch referenced by remotes/origin/HEAD.

See also:

  • "Git: Correct way to change Active Branch in a bare repository?"
  • "How do I change a Git remote HEAD to point to something besides “master”"
  • "How does origin/HEAD get set?"

Note: on Git versions older than 2.20, you need to use git branch --list (or git branch), not git branch -l.


You can use git remote set-head origin -d to delete the origin/HEAD symbolic ref, or git remote set-head origin -a to query the remote and automatically set the origin/HEAD pointer to the remote's current branch.

The origin/HEAD reference is optional. It only acts as a syntactic shortcut: If it exists and points to origin/master, you can use specific simply origin where you would otherwise specify origin/master.

The git remote(1) man page describes this:

set-head

Sets or deletes the default branch (i.e. the target of the symbolic-ref refs/remotes//HEAD) for the named remote. Having a default branch for a remote is not required, but allows the name of the remote to be specified in lieu of a specific branch. For example, if the default branch for origin is set to master, then origin may be specified wherever you would normally specify origin/master.