Retornar DataTable usando async.net 4.0

Eu tenho um método que retorna uma tabela de dados. Eu pensei usando .net 4.0 eu poderia apenas associar lógica e retornar dados. Mas esse código retorna um objeto Datatable nulo. Alguma idéia do que está errado com esse código.

public DataTable GetData(string sql, string connectionName)
{
    DataTable dt = (DataTable)GetDataAsync(sql, connectionName).AsyncState;
    return dt;
}

private async Task<DataTable> GetDataAsync(string sql, string connectionName)
{
    return await TaskEx.Run(() => { return FillData(sql, connectionName); });
}

private DataTable FillData(string sql, string connectionName)
{
    SqlConnection conn = _connections.Where(w => w.ConnectionName == connectionName).Single().Connection;
    SqlDataAdapter adp = new SqlDataAdapter(sql, conn);
    DataSet ds = new DataSet();

    adp.Fill(ds);

    return ds.Tables[0];
}

questionAnswers(3)

yourAnswerToTheQuestion