Sobrecarga de funções com base no valor vs. referência de referência

Declara algo como o seguinte

void foo(int x)        { std::cout << "foo(int)"         << std::endl; }
void foo(const int &x) { std::cout << "foo(const int &)" << std::endl; }

ever faz sentido? Como o chamador seria capaz de diferenciar entre eles? Eu tente

foo(9);  // Compiler complains ambiguous call.

int x = 9;
foo(x);  // Also ambiguous.

const int &y = x;
foo(y);  // Also ambiguous.

questionAnswers(5)

yourAnswerToTheQuestion