Consider the following example: (live demo here)
HTML:
Not sure what's the cause.
Removing the line-height and adding margins to the image does the trick.
line-height
margins
a { display: block; background: #f00; } img { margin: .3em auto; vertical-align: middle; }