lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CAKYAXd_wtGVQYgr_MUtVGGpkpqJgF56bfm0zO-nnAK0YpkT+bg@mail.gmail.com>
Date:	Wed, 16 Nov 2011 09:52:48 +0900
From:	NamJae Jeon <linkinjeon@...il.com>
To:	Joe Perches <joe@...ches.com>
Cc:	Nicolas Ferre <nicolas.ferre@...el.com>,
	David Brown <davidb@...eaurora.org>,
	Daniel Walker <dwalker@...o99.com>,
	Bryan Huntsman <bryanh@...eaurora.org>,
	Nicolas Pitre <nico@...xnic.net>, Chris Ball <cjb@...top.org>,
	Guennadi Liakhovetski <g.liakhovetski@....de>,
	Ian Molton <ian@...menth.co.uk>,
	Bruce Chang <brucechang@....com.tw>,
	Harald Welte <HaraldWelte@...tech.com>,
	Pierre Ossman <pierre@...man.eu>, linux-mmc@...r.kernel.org,
	linux-kernel@...r.kernel.org, linux-arm-kernel@...ts.infradead.org,
	linux-arm-msm@...r.kernel.org, linux-omap@...r.kernel.org
Subject: Re: [PATCH 4/4] mmc: Add mmc_host_<level> logging

2011/11/16 Joe Perches <joe@...ches.com>:
> Centralize the pr_<level> uses of mmc_hostname into specific
> mmc_host_<level> calls to allow a flexible presentation style
> and shorten the code a bit.
>
> Add mmc_host_<level> macros.
> Convert the logging calls from:
>        pr_<level>("%s: ...", mmc_hostname(foo)
> to:
>        mmc_host_<level>(foo, ...)
>
> Add a couple of missing newlines.
> Convert bare printks to pr_cont where appropriate.
> Spelling/typo fix of initialiazed to initialized.
>
> Signed-off-by: Joe Perches <joe@...ches.com>
> ---
>  drivers/mmc/card/mmc_test.c     |   66 +++++++++++---------------
>  drivers/mmc/core/bus.c          |   27 +++++------
>  drivers/mmc/core/core.c         |  101 ++++++++++++++++++---------------------
>  drivers/mmc/core/host.c         |   13 ++---
>  drivers/mmc/core/mmc.c          |   67 ++++++++++---------------
>  drivers/mmc/core/mmc_ops.c      |   11 ++--
>  drivers/mmc/core/sd.c           |   62 ++++++++---------------
>  drivers/mmc/core/sdio.c         |   10 ++--
>  drivers/mmc/core/sdio_cis.c     |    9 ++--
>  drivers/mmc/core/sdio_irq.c     |    7 +--
>  drivers/mmc/host/at91_mci.c     |    9 ++--
>  drivers/mmc/host/dw_mmc.c       |    2 +-
>  drivers/mmc/host/msm_sdcc.c     |  101 ++++++++++++++++++---------------------
>  drivers/mmc/host/mvsdio.c       |   35 ++++++--------
>  drivers/mmc/host/omap_hsmmc.c   |    7 +--
>  drivers/mmc/host/pxamci.c       |    4 +-
>  drivers/mmc/host/sdhci.c        |   81 +++++++++++++------------------
>  drivers/mmc/host/tmio_mmc.c     |    4 +-
>  drivers/mmc/host/tmio_mmc_pio.c |    4 +-
>  drivers/mmc/host/via-sdmmc.c    |   21 ++++-----
>  drivers/mmc/host/wbsd.c         |   27 +++++-----
>  include/linux/mmc/host.h        |   11 ++++
>  22 files changed, 298 insertions(+), 381 deletions(-)
>
> diff --git a/drivers/mmc/card/mmc_test.c b/drivers/mmc/card/mmc_test.c
> index f079555..5a263c6 100644
> --- a/drivers/mmc/card/mmc_test.c
> +++ b/drivers/mmc/card/mmc_test.c
> @@ -253,8 +253,7 @@ static int mmc_test_wait_busy(struct mmc_test_card *test)
>                if (!busy && mmc_test_busy(&cmd)) {
>                        busy = 1;
>                        if (test->card->host->caps & MMC_CAP_WAIT_WHILE_BUSY)
> -                               pr_info("%s: Warning: Host did not wait for busy state to end\n",
> -                                       mmc_hostname(test->card->host));
> +                               mmc_host_info(test->card->host, "Warning: Host did not wait for busy state to end\n");
>                }
>        } while (mmc_test_busy(&cmd));
>
> @@ -554,11 +553,11 @@ static void mmc_test_print_rate(struct mmc_test_card *test, uint64_t bytes,
>        rate = mmc_test_rate(bytes, &ts);
>        iops = mmc_test_rate(100, &ts); /* I/O ops per sec x 100 */
>
> -       pr_info("%s: Transfer of %u sectors (%u%s KiB) took %lu.%09lu seconds (%u kB/s, %u KiB/s, %u.%02u IOPS)\n",
> -               mmc_hostname(test->card->host), sectors, sectors >> 1,
> -               (sectors & 1 ? ".5" : ""), (unsigned long)ts.tv_sec,
> -               (unsigned long)ts.tv_nsec, rate / 1000, rate / 1024,
> -               iops / 100, iops % 100);
> +       mmc_host_info(test->card->host, "Transfer of %u sectors (%u%s KiB) took %lu.%09lu seconds (%u kB/s, %u KiB/s, %u.%02u IOPS)\n",
> +                     sectors, sectors >> 1,
> +                     (sectors & 1 ? ".5" : ""), (unsigned long)ts.tv_sec,
> +                     (unsigned long)ts.tv_nsec, rate / 1000, rate / 1024,
> +                     iops / 100, iops % 100);
>
>        mmc_test_save_transfer_result(test, 1, sectors, ts, rate, iops);
>  }
> @@ -579,12 +578,12 @@ static void mmc_test_print_avg_rate(struct mmc_test_card *test, uint64_t bytes,
>        rate = mmc_test_rate(tot, &ts);
>        iops = mmc_test_rate(count * 100, &ts); /* I/O ops per sec x 100 */
>
> -       pr_info("%s: Transfer of %u x %u sectors (%u x %u%s KiB) took %lu.%09lu seconds (%u kB/s, %u KiB/s, %u.%02u IOPS, sg_len %d)\n",
> -               mmc_hostname(test->card->host), count, sectors, count,
> -               sectors >> 1, (sectors & 1 ? ".5" : ""),
> -               (unsigned long)ts.tv_sec, (unsigned long)ts.tv_nsec,
> -               rate / 1000, rate / 1024, iops / 100, iops % 100,
> -               test->area.sg_len);
> +       mmc_host_info(test->card->host, "Transfer of %u x %u sectors (%u x %u%s KiB) took %lu.%09lu seconds (%u kB/s, %u KiB/s, %u.%02u IOPS, sg_len %d)\n",
> +                     count, sectors, count,
> +                     sectors >> 1, (sectors & 1 ? ".5" : ""),
> +                     (unsigned long)ts.tv_sec, (unsigned long)ts.tv_nsec,
> +                     rate / 1000, rate / 1024, iops / 100, iops % 100,
> +                     test->area.sg_len);
I don't know why pr_info should be surely replaced by mmc_host_info.
if it is needed for only host name, I think that existing
pr_info/err/debug is sufficient.

>
>        mmc_test_save_transfer_result(test, count, sectors, ts, rate, iops);
>  }
> @@ -1407,8 +1406,7 @@ static int mmc_test_multi_read_high(struct mmc_test_card *test)
>
>  static int mmc_test_no_highmem(struct mmc_test_card *test)
>  {
> -       pr_info("%s: Highmem not configured - test skipped\n",
> -               mmc_hostname(test->card->host));
> +       mmc_host_info(test->card->host, "Highmem not configured - test skipped\n");
>        return 0;
>  }
>
> @@ -1434,8 +1432,7 @@ static int mmc_test_area_map(struct mmc_test_card *test, unsigned long sz,
>                                      t->max_seg_sz, &t->sg_len, min_sg_len);
>        }
>        if (err)
> -               pr_info("%s: Failed to map sg list\n",
> -                       mmc_hostname(test->card->host));
> +               mmc_host_info(test->card->host, "Failed to map sg list\n");
>        return err;
>  }
>
> @@ -2689,8 +2686,8 @@ static void mmc_test_run(struct mmc_test_card *test, int testcase)
>  {
>        int i, ret;
>
> -       pr_info("%s: Starting tests of card %s...\n",
> -               mmc_hostname(test->card->host), mmc_card_id(test->card));
> +       mmc_host_info(test->card->host, "Starting tests of card %s...\n",
> +                     mmc_card_id(test->card));
>
>        mmc_claim_host(test->card->host);
>
> @@ -2700,16 +2697,14 @@ static void mmc_test_run(struct mmc_test_card *test, int testcase)
>                if (testcase && ((i + 1) != testcase))
>                        continue;
>
> -               pr_info("%s: Test case %d. %s...\n",
> -                       mmc_hostname(test->card->host), i + 1,
> -                       mmc_test_cases[i].name);
> +               mmc_host_info(test->card->host, "Test case %d. %s...\n",
> +                             i + 1, mmc_test_cases[i].name);
>
>                if (mmc_test_cases[i].prepare) {
>                        ret = mmc_test_cases[i].prepare(test);
>                        if (ret) {
> -                               pr_info("%s: Result: Prepare stage failed! (%d)\n",
> -                                       mmc_hostname(test->card->host),
> -                                       ret);
> +                               mmc_host_info(test->card->host, "Result: Prepare stage failed! (%d)\n",
> +                                             ret);
>                                continue;
>                        }
>                }
> @@ -2736,24 +2731,20 @@ static void mmc_test_run(struct mmc_test_card *test, int testcase)
>                ret = mmc_test_cases[i].run(test);
>                switch (ret) {
>                case RESULT_OK:
> -                       pr_info("%s: Result: OK\n",
> -                               mmc_hostname(test->card->host));
> +                       mmc_host_info(test->card->host, "Result: OK\n");
>                        break;
>                case RESULT_FAIL:
> -                       pr_info("%s: Result: FAILED\n",
> -                               mmc_hostname(test->card->host));
> +                       mmc_host_info(test->card->host, "Result: FAILED\n");
>                        break;
>                case RESULT_UNSUP_HOST:
> -                       pr_info("%s: Result: UNSUPPORTED (by host)\n",
> -                               mmc_hostname(test->card->host));
> +                       mmc_host_info(test->card->host, "Result: UNSUPPORTED (by host)\n");
>                        break;
>                case RESULT_UNSUP_CARD:
> -                       pr_info("%s: Result: UNSUPPORTED (by card)\n",
> -                               mmc_hostname(test->card->host));
> +                       mmc_host_info(test->card->host, "Result: UNSUPPORTED (by card)\n");
>                        break;
>                default:
> -                       pr_info("%s: Result: ERROR (%d)\n",
> -                               mmc_hostname(test->card->host), ret);
> +                       mmc_host_info(test->card->host, "Result: ERROR (%d)\n",
> +                                     ret);
>                }
>
>                /* Save the result */
> @@ -2763,8 +2754,7 @@ static void mmc_test_run(struct mmc_test_card *test, int testcase)
>                if (mmc_test_cases[i].cleanup) {
>                        ret = mmc_test_cases[i].cleanup(test);
>                        if (ret) {
> -                               pr_info("%s: Warning: Cleanup stage failed! (%d)\n",
> -                                       mmc_hostname(test->card->host),
> +                               mmc_host_info(test->card->host, "Warning: Cleanup stage failed! (%d)\n",
>                                        ret);
>                        }
>                }
> @@ -2772,7 +2762,7 @@ static void mmc_test_run(struct mmc_test_card *test, int testcase)
>
>        mmc_release_host(test->card->host);
>
> -       pr_info("%s: Tests completed\n", mmc_hostname(test->card->host));
> +       mmc_host_info(test->card->host, "Tests completed\n");
>  }
>
>  static void mmc_test_free_result(struct mmc_card *card)
> diff --git a/drivers/mmc/core/bus.c b/drivers/mmc/core/bus.c
> index 2e1f028..e976d85 100644
> --- a/drivers/mmc/core/bus.c
> +++ b/drivers/mmc/core/bus.c
> @@ -297,18 +297,16 @@ int mmc_add_card(struct mmc_card *card)
>        }
>
>        if (mmc_host_is_spi(card->host)) {
> -               pr_info("%s: new %s%s%s card on SPI\n",
> -                       mmc_hostname(card->host),
> -                       mmc_card_highspeed(card) ? "high speed " : "",
> -                       mmc_card_ddr_mode(card) ? "DDR " : "",
> -                       type);
> +               mmc_host_info(card->host, "new %s%s%s card on SPI\n",
> +                             mmc_card_highspeed(card) ? "high speed " : "",
> +                             mmc_card_ddr_mode(card) ? "DDR " : "",
> +                             type);
>        } else {
> -               pr_info("%s: new %s%s%s card at address %04x\n",
> -                       mmc_hostname(card->host),
> -                       mmc_sd_card_uhs(card) ? "ultra high speed " :
> -                       mmc_card_highspeed(card) ? "high speed " : "",
> -                       mmc_card_ddr_mode(card) ? "DDR " : "",
> -                       type, card->rca);
> +               mmc_host_info(card->host, "new %s%s%s card at address %04x\n",
> +                             mmc_sd_card_uhs(card) ? "ultra high speed " :
> +                             mmc_card_highspeed(card) ? "high speed " : "",
> +                             mmc_card_ddr_mode(card) ? "DDR " : "",
> +                             type, card->rca);
>        }
>
>  #ifdef CONFIG_DEBUG_FS
> @@ -336,11 +334,10 @@ void mmc_remove_card(struct mmc_card *card)
>
>        if (mmc_card_present(card)) {
>                if (mmc_host_is_spi(card->host)) {
> -                       pr_info("%s: SPI card removed\n",
> -                               mmc_hostname(card->host));
> +                       mmc_host_info(card->host, "SPI card removed\n");
>                } else {
> -                       pr_info("%s: card %04x removed\n",
> -                               mmc_hostname(card->host), card->rca);
> +                       mmc_host_info(card->host, "card %04x removed\n",
> +                                     card->rca);
>                }
>                device_del(&card->dev);
>        }
> diff --git a/drivers/mmc/core/core.c b/drivers/mmc/core/core.c
> index 39e1311..39779d7 100644
> --- a/drivers/mmc/core/core.c
> +++ b/drivers/mmc/core/core.c
> @@ -155,23 +155,23 @@ void mmc_request_done(struct mmc_host *host, struct mmc_request *mrq)
>
>                led_trigger_event(host->led, LED_OFF);
>
> -               pr_debug("%s: req done (CMD%u): %d: %08x %08x %08x %08x\n",
> -                        mmc_hostname(host), cmd->opcode, err,
> -                        cmd->resp[0], cmd->resp[1],
> -                        cmd->resp[2], cmd->resp[3]);
> +               mmc_host_debug(host, "req done (CMD%u): %d: %08x %08x %08x %08x\n",
> +                              cmd->opcode, err,
> +                              cmd->resp[0], cmd->resp[1],
> +                              cmd->resp[2], cmd->resp[3]);
>
>                if (mrq->data) {
> -                       pr_debug("%s:     %d bytes transferred: %d\n",
> -                                mmc_hostname(host),
> -                                mrq->data->bytes_xfered, mrq->data->error);
> +                       mmc_host_debug(host, "    %d bytes transferred: %d\n",
> +                                      mrq->data->bytes_xfered,
> +                                      mrq->data->error);
>                }
>
>                if (mrq->stop) {
> -                       pr_debug("%s:     (CMD%u): %d: %08x %08x %08x %08x\n",
> -                                mmc_hostname(host), mrq->stop->opcode,
> -                                mrq->stop->error,
> -                                mrq->stop->resp[0], mrq->stop->resp[1],
> -                                mrq->stop->resp[2], mrq->stop->resp[3]);
> +                       mmc_host_debug(host, "    (CMD%u): %d: %08x %08x %08x %08x\n",
> +                                      mrq->stop->opcode,
> +                                      mrq->stop->error,
> +                                      mrq->stop->resp[0], mrq->stop->resp[1],
> +                                      mrq->stop->resp[2], mrq->stop->resp[3]);
>                }
>
>                if (mrq->done)
> @@ -191,22 +191,21 @@ mmc_start_request(struct mmc_host *host, struct mmc_request *mrq)
>        struct scatterlist *sg;
>  #endif
>
> -       pr_debug("%s: starting CMD%u arg %08x flags %08x\n",
> -                mmc_hostname(host), mrq->cmd->opcode,
> -                mrq->cmd->arg, mrq->cmd->flags);
> +       mmc_host_debug(host, "starting CMD%u arg %08x flags %08x\n",
> +                      mrq->cmd->opcode, mrq->cmd->arg, mrq->cmd->flags);
>
>        if (mrq->data) {
> -               pr_debug("%s:     blksz %d blocks %d flags %08x tsac %d ms nsac %d\n",
> -                        mmc_hostname(host), mrq->data->blksz,
> -                        mrq->data->blocks, mrq->data->flags,
> -                        mrq->data->timeout_ns / 1000000,
> -                        mrq->data->timeout_clks);
> +               mmc_host_debug(host, "    blksz %d blocks %d flags %08x tsac %d ms nsac %d\n",
> +                              mrq->data->blksz,
> +                              mrq->data->blocks, mrq->data->flags,
> +                              mrq->data->timeout_ns / 1000000,
> +                              mrq->data->timeout_clks);
>        }
>
>        if (mrq->stop) {
> -               pr_debug("%s:     CMD%u arg %08x flags %08x\n",
> -                        mmc_hostname(host), mrq->stop->opcode,
> -                        mrq->stop->arg, mrq->stop->flags);
> +               mmc_host_debug(host, "    CMD%u arg %08x flags %08x\n",
> +                              mrq->stop->opcode,
> +                              mrq->stop->arg, mrq->stop->flags);
>        }
>
>        WARN_ON(!host->claimed);
> @@ -264,8 +263,8 @@ static void mmc_wait_for_req_done(struct mmc_host *host,
>                if (!cmd->error || !cmd->retries)
>                        break;
>
> -               pr_debug("%s: req failed (CMD%u): %d, retrying...\n",
> -                        mmc_hostname(host), cmd->opcode, cmd->error);
> +               mmc_host_debug(host, "req failed (CMD%u): %d, retrying...\n",
> +                              cmd->opcode, cmd->error);
>                cmd->retries--;
>                cmd->error = 0;
>                host->ops->request(host, mrq);
> @@ -396,14 +395,14 @@ int mmc_interrupt_hpi(struct mmc_card *card)
>        BUG_ON(!card);
>
>        if (!card->ext_csd.hpi_en) {
> -               pr_info("%s: HPI enable bit unset\n", mmc_hostname(card->host));
> +               mmc_host_info(card->host, "HPI enable bit unset\n");
>                return 1;
>        }
>
>        mmc_claim_host(card->host);
>        err = mmc_send_status(card, &status);
>        if (err) {
> -               pr_err("%s: Get card status fail\n", mmc_hostname(card->host));
> +               mmc_host_err(card->host, "Get card status fail\n");
>                goto out;
>        }
>
> @@ -422,15 +421,15 @@ int mmc_interrupt_hpi(struct mmc_card *card)
>                         */
>                        err = mmc_send_hpi_cmd(card, &status);
>                        if (err)
> -                               pr_debug("%s: abort HPI (%d error)\n",
> -                                        mmc_hostname(card->host), err);
> +                               mmc_host_debug(card->host, "abort HPI (%d error)\n",
> +                                              err);
>
>                        err = mmc_send_status(card, &status);
>                        if (err)
>                                break;
>                } while (R1_CURRENT_STATE(status) == R1_STATE_PRG);
>        } else
> -               pr_debug("%s: Left prg-state\n", mmc_hostname(card->host));
> +               mmc_host_debug(card->host, "Left prg-state\n");
>
>  out:
>        mmc_release_host(card->host);
> @@ -620,8 +619,7 @@ int mmc_host_enable(struct mmc_host *host)
>                host->en_dis_recurs = 0;
>
>                if (err) {
> -                       pr_debug("%s: enable error %d\n",
> -                                mmc_hostname(host), err);
> +                       mmc_host_debug(host, "enable error %d\n", err);
>                        return err;
>                }
>        }
> @@ -640,8 +638,7 @@ static int mmc_host_do_disable(struct mmc_host *host, int lazy)
>                host->en_dis_recurs = 0;
>
>                if (err < 0) {
> -                       pr_debug("%s: disable error %d\n",
> -                                mmc_hostname(host), err);
> +                       mmc_host_debug(host, "disable error %d\n", err);
>                        return err;
>                }
>                if (err > 0) {
> @@ -844,10 +841,10 @@ static inline void mmc_set_ios(struct mmc_host *host)
>  {
>        struct mmc_ios *ios = &host->ios;
>
> -       pr_debug("%s: clock %uHz busmode %u powermode %u cs %u Vdd %u width %u timing %u\n",
> -                mmc_hostname(host), ios->clock, ios->bus_mode,
> -                ios->power_mode, ios->chip_select, ios->vdd,
> -                ios->bus_width, ios->timing);
> +       mmc_host_debug(host, "clock %uHz busmode %u powermode %u cs %u Vdd %u width %u timing %u\n",
> +                      ios->clock, ios->bus_mode,
> +                      ios->power_mode, ios->chip_select, ios->vdd,
> +                      ios->bus_width, ios->timing);
>
>        if (ios->clock > 0)
>                mmc_set_ungated(host);
> @@ -1164,8 +1161,7 @@ u32 mmc_select_voltage(struct mmc_host *host, u32 ocr)
>                mmc_set_ios(host);
>                mmc_host_clk_release(host);
>        } else {
> -               pr_warn("%s: host doesn't support card's voltages\n",
> -                       mmc_hostname(host));
> +               mmc_host_warn(host, "host doesn't support card's voltages\n");
>                ocr = 0;
>        }
>
> @@ -1893,8 +1889,8 @@ unsigned int mmc_calc_max_discard(struct mmc_card *card)
>        } else if (max_discard < card->erase_size) {
>                max_discard = 0;
>        }
> -       pr_debug("%s: calculated max. discard sectors %u for timeout %u ms\n",
> -                mmc_hostname(host), max_discard, host->max_discard_to);
> +       mmc_host_debug(host, "calculated max. discard sectors %u for timeout %u ms\n",
> +                      max_discard, host->max_discard_to);
>        return max_discard;
>  }
>  EXPORT_SYMBOL(mmc_calc_max_discard);
> @@ -2006,8 +2002,8 @@ static int mmc_rescan_try_freq(struct mmc_host *host, unsigned freq)
>        host->f_init = freq;
>
>  #ifdef CONFIG_MMC_DEBUG
> -       pr_info("%s: %s: trying to init card at %u Hz\n",
> -               mmc_hostname(host), __func__, host->f_init);
> +       mmc_host_info(host, "%s: trying to init card at %u Hz\n",
> +                     __func__, host->f_init);
>  #endif
>        mmc_power_up(host);
>
> @@ -2142,7 +2138,7 @@ int mmc_power_save_host(struct mmc_host *host)
>        int ret = 0;
>
>  #ifdef CONFIG_MMC_DEBUG
> -       pr_info("%s: %s: powering down\n", mmc_hostname(host), __func__);
> +       mmc_host_info(host, "%s: powering down\n", __func__);
>  #endif
>
>        mmc_bus_get(host);
> @@ -2168,7 +2164,7 @@ int mmc_power_restore_host(struct mmc_host *host)
>        int ret;
>
>  #ifdef CONFIG_MMC_DEBUG
> -       pr_info("%s: %s: powering up\n", mmc_hostname(host), __func__);
> +       mmc_host_info(host, "%s: powering up\n", __func__);
>  #endif
>
>        mmc_bus_get(host);
> @@ -2244,8 +2240,7 @@ int mmc_flush_cache(struct mmc_card *card)
>                err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL,
>                                EXT_CSD_FLUSH_CACHE, 1, 0);
>                if (err)
> -                       pr_err("%s: cache flush error %d\n",
> -                              mmc_hostname(card->host), err);
> +                       mmc_host_err(card->host, "cache flush error %d\n", err);
>        }
>
>        return err;
> @@ -2274,10 +2269,8 @@ int mmc_cache_ctrl(struct mmc_host *host, u8 enable)
>                        err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL,
>                                        EXT_CSD_CACHE_CTRL, enable, 0);
>                if (err)
> -                       pr_err("%s: cache %s error %d\n",
> -                              mmc_hostname(card->host),
> -                              enable ? "on" : "off",
> -                              err);
> +                       mmc_host_err(card->host, "cache %s error %d\n",
> +                                    enable ? "on" : "off", err);
>                else
>                        card->ext_csd.cache_ctrl = enable;
>        }
> @@ -2375,8 +2368,8 @@ int mmc_resume_host(struct mmc_host *host)
>                BUG_ON(!host->bus_ops->resume);
>                err = host->bus_ops->resume(host);
>                if (err) {
> -                       pr_warn("%s: error %d during resume (card was removed?)\n",
> -                               mmc_hostname(host), err);
> +                       mmc_host_warn(host, "error %d during resume (card was removed?)\n",
> +                                     err);
>                        err = 0;
>                }
>        }
> diff --git a/drivers/mmc/core/host.c b/drivers/mmc/core/host.c
> index 7f963c0..40d177f 100644
> --- a/drivers/mmc/core/host.c
> +++ b/drivers/mmc/core/host.c
> @@ -75,8 +75,7 @@ static ssize_t clkgate_delay_store(struct device *dev,
>        host->clkgate_delay = value;
>        spin_unlock_irqrestore(&host->clk_lock, flags);
>
> -       pr_info("%s: clock gate delay set to %lu ms\n",
> -                       mmc_hostname(host), value);
> +       mmc_host_info(host, "clock gate delay set to %lu ms\n", value);
>        return count;
>  }
>
> @@ -94,8 +93,7 @@ static void mmc_host_clk_gate_delayed(struct mmc_host *host)
>        unsigned long flags;
>
>        if (!freq) {
> -               pr_debug("%s: frequency set to 0 in disable function, this means the clock is already disabled\n",
> -                        mmc_hostname(host));
> +               mmc_host_debug(host, "frequency set to 0 in disable function, this means the clock is already disabled\n");
>                return;
>        }
>        /*
> @@ -126,7 +124,7 @@ static void mmc_host_clk_gate_delayed(struct mmc_host *host)
>                /* This will set host->ios.clock to 0 */
>                mmc_gate_clock(host);
>                spin_lock_irqsave(&host->clk_lock, flags);
> -               pr_debug("%s: gated MCI clock\n", mmc_hostname(host));
> +               mmc_host_debug(host, "gated MCI clock\n");
>        }
>        spin_unlock_irqrestore(&host->clk_lock, flags);
>        mutex_unlock(&host->clk_gate_mutex);
> @@ -163,7 +161,7 @@ void mmc_host_clk_hold(struct mmc_host *host)
>                spin_unlock_irqrestore(&host->clk_lock, flags);
>                mmc_ungate_clock(host);
>                spin_lock_irqsave(&host->clk_lock, flags);
> -               pr_debug("%s: ungated MCI clock\n", mmc_hostname(host));
> +               mmc_host_debug(host, "ungated MCI clock\n");
>        }
>        host->clk_requests++;
>        spin_unlock_irqrestore(&host->clk_lock, flags);
> @@ -277,8 +275,7 @@ static inline void mmc_host_clk_sysfs_init(struct mmc_host *host)
>        host->clkgate_delay_attr.attr.name = "clkgate_delay";
>        host->clkgate_delay_attr.attr.mode = S_IRUGO | S_IWUSR;
>        if (device_create_file(&host->class_dev, &host->clkgate_delay_attr))
> -               pr_err("%s: Failed to create clkgate_delay sysfs entry\n",
> -                               mmc_hostname(host));
> +               mmc_host_err(host, "Failed to create clkgate_delay sysfs entry\n");
>  }
>  #else
>
> diff --git a/drivers/mmc/core/mmc.c b/drivers/mmc/core/mmc.c
> index f6db788..c7efe5a 100644
> --- a/drivers/mmc/core/mmc.c
> +++ b/drivers/mmc/core/mmc.c
> @@ -102,8 +102,8 @@ static int mmc_decode_cid(struct mmc_card *card)
>                break;
>
>        default:
> -               pr_err("%s: card has unknown MMCA version %d\n",
> -                       mmc_hostname(card->host), card->csd.mmca_vsn);
> +               mmc_host_err(card->host, "card has unknown MMCA version %d\n",
> +                            card->csd.mmca_vsn);
>                return -EINVAL;
>        }
>
> @@ -136,8 +136,8 @@ static int mmc_decode_csd(struct mmc_card *card)
>         */
>        csd->structure = UNSTUFF_BITS(resp, 126, 2);
>        if (csd->structure == 0) {
> -               pr_err("%s: unrecognised CSD structure version %d\n",
> -                       mmc_hostname(card->host), csd->structure);
> +               mmc_host_err(card->host, "unrecognised CSD structure version %d\n",
> +                            csd->structure);
>                return -EINVAL;
>        }
>
> @@ -196,8 +196,7 @@ static int mmc_get_ext_csd(struct mmc_card *card, u8 **new_ext_csd)
>         */
>        ext_csd = kmalloc(512, GFP_KERNEL);
>        if (!ext_csd) {
> -               pr_err("%s: could not allocate a buffer to receive the ext_csd\n",
> -                      mmc_hostname(card->host));
> +               mmc_host_err(card->host, "could not allocate a buffer to receive the ext_csd\n");
>                return -ENOMEM;
>        }
>
> @@ -218,11 +217,9 @@ static int mmc_get_ext_csd(struct mmc_card *card, u8 **new_ext_csd)
>                 * stored in their CSD.
>                 */
>                if (card->csd.capacity == (4096 * 512)) {
> -                       pr_err("%s: unable to read EXT_CSD on a possible high capacity card. Card will be ignored.\n",
> -                              mmc_hostname(card->host));
> +                       mmc_host_err(card->host, "unable to read EXT_CSD on a possible high capacity card. Card will be ignored.\n");
>                } else {
> -                       pr_warn("%s: unable to read EXT_CSD, performance might suffer\n",
> -                               mmc_hostname(card->host));
> +                       mmc_host_warn(card->host, "unable to read EXT_CSD, performance might suffer\n");
>                        err = 0;
>                }
>        } else
> @@ -249,9 +246,8 @@ static int mmc_read_ext_csd(struct mmc_card *card, u8 *ext_csd)
>        card->ext_csd.raw_ext_csd_structure = ext_csd[EXT_CSD_STRUCTURE];
>        if (card->csd.structure == 3) {
>                if (card->ext_csd.raw_ext_csd_structure > 2) {
> -                       pr_err("%s: unrecognised EXT_CSD structure version %d\n",
> -                              mmc_hostname(card->host),
> -                              card->ext_csd.raw_ext_csd_structure);
> +                       mmc_host_err(card->host, "unrecognised EXT_CSD structure version %d\n",
> +                                    card->ext_csd.raw_ext_csd_structure);
>                        err = -EINVAL;
>                        goto out;
>                }
> @@ -259,8 +255,8 @@ static int mmc_read_ext_csd(struct mmc_card *card, u8 *ext_csd)
>
>        card->ext_csd.rev = ext_csd[EXT_CSD_REV];
>        if (card->ext_csd.rev > 6) {
> -               pr_err("%s: unrecognised EXT_CSD revision %d\n",
> -                       mmc_hostname(card->host), card->ext_csd.rev);
> +               mmc_host_err(card->host, "unrecognised EXT_CSD revision %d\n",
> +                            card->ext_csd.rev);
>                err = -EINVAL;
>                goto out;
>        }
> @@ -305,8 +301,7 @@ static int mmc_read_ext_csd(struct mmc_card *card, u8 *ext_csd)
>                break;
>        default:
>                /* MMC v4 spec says this cannot happen */
> -               pr_warn("%s: card is mmc v4 but doesn't support any high-speed modes\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "card is mmc v4 but doesn't support any high-speed modes\n");
>        }
>
>        card->ext_csd.raw_s_a_timeout = ext_csd[EXT_CSD_S_A_TIMEOUT];
> @@ -659,8 +654,7 @@ static int mmc_select_powerclass(struct mmc_card *card,
>                        index = EXT_CSD_PWR_CL_200_360;
>                break;
>        default:
> -               pr_warn("%s: Voltage range not supported for power class\n",
> -                       mmc_hostname(host));
> +               mmc_host_warn(host, "Voltage range not supported for power class\n");
>                return -EINVAL;
>        }
>
> @@ -899,8 +893,7 @@ static int mmc_init_card(struct mmc_host *host, u32 ocr,
>                        goto free_card;
>
>                if (err) {
> -                       pr_warn("%s: switch to highspeed failed\n",
> -                               mmc_hostname(card->host));
> +                       mmc_host_warn(card->host, "switch to highspeed failed\n");
>                        err = 0;
>                } else {
>                        mmc_card_set_highspeed(card);
> @@ -917,8 +910,7 @@ static int mmc_init_card(struct mmc_host *host, u32 ocr,
>                if (err && err != -EBADMSG)
>                        goto free_card;
>                if (err) {
> -                       pr_warn("%s: Enabling HPI failed\n",
> -                               mmc_hostname(card->host));
> +                       mmc_host_warn(card->host, "Enabling HPI failed\n");
>                        err = 0;
>                } else
>                        card->ext_csd.hpi_en = 1;
> @@ -982,9 +974,8 @@ static int mmc_init_card(struct mmc_host *host, u32 ocr,
>                        err = mmc_select_powerclass(card, ext_csd_bits[idx][0],
>                                                    ext_csd);
>                        if (err)
> -                               pr_err("%s: power class selection to bus width %d failed\n",
> -                                      mmc_hostname(card->host),
> -                                      1 << bus_width);
> +                               mmc_host_err(card->host, "power class selection to bus width %d failed\n",
> +                                            1 << bus_width);
>
>                        err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL,
>                                         EXT_CSD_BUS_WIDTH,
> @@ -1012,9 +1003,8 @@ static int mmc_init_card(struct mmc_host *host, u32 ocr,
>                        err = mmc_select_powerclass(card, ext_csd_bits[idx][1],
>                                                    ext_csd);
>                        if (err)
> -                               pr_err("%s: power class selection to bus width %d ddr %d failed\n",
> -                                      mmc_hostname(card->host),
> -                                      1 << bus_width, ddr);
> +                               mmc_host_err(card->host, "power class selection to bus width %d ddr %d failed\n",
> +                                            1 << bus_width, ddr);
>
>                        err = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL,
>                                         EXT_CSD_BUS_WIDTH,
> @@ -1022,9 +1012,8 @@ static int mmc_init_card(struct mmc_host *host, u32 ocr,
>                                         card->ext_csd.generic_cmd6_time);
>                }
>                if (err) {
> -                       pr_warn("%s: switch to bus width %d ddr %d failed\n",
> -                               mmc_hostname(card->host),
> -                               1 << bus_width, ddr);
> +                       mmc_host_warn(card->host, "switch to bus width %d ddr %d failed\n",
> +                                     1 << bus_width, ddr);
>                        goto free_card;
>                } else if (ddr) {
>                        /*
> @@ -1187,8 +1176,8 @@ static int mmc_sleep(struct mmc_host *host)
>        if (card && card->ext_csd.rev >= 3) {
>                err = mmc_card_sleepawake(host, 1);
>                if (err < 0)
> -                       pr_debug("%s: Error %d while putting card into sleep",
> -                                mmc_hostname(host), err);
> +                       mmc_host_debug(host, "Error %d while putting card into sleep\n",
> +                                      err);
>        }
>
>        return err;
> @@ -1202,8 +1191,8 @@ static int mmc_awake(struct mmc_host *host)
>        if (card && card->ext_csd.rev >= 3) {
>                err = mmc_card_sleepawake(host, 0);
>                if (err < 0)
> -                       pr_debug("%s: Error %d while awaking sleeping card",
> -                                mmc_hostname(host), err);
> +                       mmc_host_debug(host, "Error %d while awaking sleeping card\n",
> +                                      err);
>        }
>
>        return err;
> @@ -1277,8 +1266,7 @@ int mmc_attach_mmc(struct mmc_host *host)
>         * support.
>         */
>        if (ocr & 0x7F) {
> -               pr_warn("%s: card claims to support voltages below the defined range. These will be ignored.\n",
> -                       mmc_hostname(host));
> +               mmc_host_warn(host, "card claims to support voltages below the defined range. These will be ignored.\n");
>                ocr &= ~0x7F;
>        }
>
> @@ -1315,8 +1303,7 @@ remove_card:
>  err:
>        mmc_detach_bus(host);
>
> -       pr_err("%s: error %d whilst initialising MMC card\n",
> -               mmc_hostname(host), err);
> +       mmc_host_err(host, "error %d whilst initialising MMC card\n", err);
>
>        return err;
>  }
> diff --git a/drivers/mmc/core/mmc_ops.c b/drivers/mmc/core/mmc_ops.c
> index 7c7388c..c1e0b9c 100644
> --- a/drivers/mmc/core/mmc_ops.c
> +++ b/drivers/mmc/core/mmc_ops.c
> @@ -415,8 +415,8 @@ int mmc_switch(struct mmc_card *card, u8 set, u8 index, u8 value,
>                        return -EBADMSG;
>        } else {
>                if (status & 0xFDFFA000)
> -                       pr_warn("%s: unexpected status %#x after switch\n",
> -                               mmc_hostname(card->host), status);
> +                       mmc_host_warn(card->host, "unexpected status %#x after switch\n",
> +                                     status);
>                if (status & R1_SWITCH_ERROR)
>                        return -EBADMSG;
>        }
> @@ -477,8 +477,7 @@ mmc_send_bus_test(struct mmc_card *card, struct mmc_host *host, u8 opcode,
>        else if (len == 4)
>                test_buf = testdata_4bit;
>        else {
> -               pr_err("%s: Invalid bus_width %d\n",
> -                      mmc_hostname(host), len);
> +               mmc_host_err(host, "Invalid bus_width %d\n", len);
>                kfree(data_buf);
>                return -EINVAL;
>        }
> @@ -569,8 +568,8 @@ int mmc_send_hpi_cmd(struct mmc_card *card, u32 *status)
>
>        err = mmc_wait_for_cmd(card->host, &cmd, 0);
>        if (err) {
> -               pr_warn("%s: error %d interrupting operation. HPI command response %#x\n",
> -                       mmc_hostname(card->host), err, cmd.resp[0]);
> +               mmc_host_warn(card->host, "error %d interrupting operation. HPI command response %#x\n",
> +                             err, cmd.resp[0]);
>                return err;
>        }
>        if (status)
> diff --git a/drivers/mmc/core/sd.c b/drivers/mmc/core/sd.c
> index 1492b7b..2b0fba9 100644
> --- a/drivers/mmc/core/sd.c
> +++ b/drivers/mmc/core/sd.c
> @@ -166,8 +166,8 @@ static int mmc_decode_csd(struct mmc_card *card)
>                csd->erase_size = 1;
>                break;
>        default:
> -               pr_err("%s: unrecognised CSD structure version %d\n",
> -                       mmc_hostname(card->host), csd_struct);
> +               mmc_host_err(card->host, "unrecognised CSD structure version %d\n",
> +                            csd_struct);
>                return -EINVAL;
>        }
>
> @@ -190,8 +190,8 @@ static int mmc_decode_scr(struct mmc_card *card)
>
>        scr_struct = UNSTUFF_BITS(resp, 60, 4);
>        if (scr_struct != 0) {
> -               pr_err("%s: unrecognised SCR structure version %d\n",
> -                       mmc_hostname(card->host), scr_struct);
> +               mmc_host_err(card->host, "unrecognised SCR structure version %d\n",
> +                            scr_struct);
>                return -EINVAL;
>        }
>
> @@ -221,8 +221,7 @@ static int mmc_read_ssr(struct mmc_card *card)
>        u32 *ssr;
>
>        if (!(card->csd.cmdclass & CCC_APP_SPEC)) {
> -               pr_warn("%s: card lacks mandatory SD Status function\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "card lacks mandatory SD Status function\n");
>                return 0;
>        }
>
> @@ -232,8 +231,7 @@ static int mmc_read_ssr(struct mmc_card *card)
>
>        err = mmc_app_sd_status(card, ssr);
>        if (err) {
> -               pr_warn("%s: problem reading SD Status register\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "problem reading SD Status register\n");
>                err = 0;
>                goto out;
>        }
> @@ -256,8 +254,7 @@ static int mmc_read_ssr(struct mmc_card *card)
>                        card->ssr.erase_offset = eo * 1000;
>                }
>        } else {
> -               pr_warn("%s: SD Status: Invalid Allocation Unit size\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "SD Status: Invalid Allocation Unit size\n");
>        }
>  out:
>        kfree(ssr);
> @@ -276,8 +273,7 @@ static int mmc_read_switch(struct mmc_card *card)
>                return 0;
>
>        if (!(card->csd.cmdclass & CCC_SWITCH)) {
> -               pr_warn("%s: card lacks mandatory switch function, performance might suffer\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "card lacks mandatory switch function, performance might suffer\n");
>                return 0;
>        }
>
> @@ -285,8 +281,7 @@ static int mmc_read_switch(struct mmc_card *card)
>
>        status = kmalloc(64, GFP_KERNEL);
>        if (!status) {
> -               pr_err("%s: could not allocate a buffer for switch capabilities\n",
> -                      mmc_hostname(card->host));
> +               mmc_host_err(card->host, "could not allocate a buffer for switch capabilities\n");
>                return -ENOMEM;
>        }
>
> @@ -300,8 +295,7 @@ static int mmc_read_switch(struct mmc_card *card)
>                if (err != -EINVAL && err != -ENOSYS && err != -EFAULT)
>                        goto out;
>
> -               pr_warn("%s: problem reading Bus Speed modes\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "problem reading Bus Speed modes\n");
>                err = 0;
>
>                goto out;
> @@ -323,8 +317,7 @@ static int mmc_read_switch(struct mmc_card *card)
>                        if (err != -EINVAL && err != -ENOSYS && err != -EFAULT)
>                                goto out;
>
> -                       pr_warn("%s: problem reading Driver Strength\n",
> -                               mmc_hostname(card->host));
> +                       mmc_host_warn(card->host, "problem reading Driver Strength\n");
>                        err = 0;
>
>                        goto out;
> @@ -342,8 +335,7 @@ static int mmc_read_switch(struct mmc_card *card)
>                        if (err != -EINVAL && err != -ENOSYS && err != -EFAULT)
>                                goto out;
>
> -                       pr_warn("%s: problem reading Current Limit\n",
> -                               mmc_hostname(card->host));
> +                       mmc_host_warn(card->host, "problem reading Current Limit\n");
>                        err = 0;
>
>                        goto out;
> @@ -382,8 +374,7 @@ int mmc_sd_switch_hs(struct mmc_card *card)
>
>        status = kmalloc(64, GFP_KERNEL);
>        if (!status) {
> -               pr_err("%s: could not allocate a buffer for switch capabilities\n",
> -                      mmc_hostname(card->host));
> +               mmc_host_err(card->host, "could not allocate a buffer for switch capabilities\n");
>                return -ENOMEM;
>        }
>
> @@ -392,8 +383,7 @@ int mmc_sd_switch_hs(struct mmc_card *card)
>                goto out;
>
>        if ((status[16] & 0xF) != 1) {
> -               pr_warn("%s: problem switching card into high-speed mode!\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "problem switching card into high-speed mode!\n");
>                err = 0;
>        } else {
>                err = 1;
> @@ -457,8 +447,7 @@ static int sd_select_driver_type(struct mmc_card *card, u8 *status)
>                return err;
>
>        if ((status[15] & 0xF) != drive_strength) {
> -               pr_warn("%s: problem setting drive strength!\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "problem setting drive strength!\n");
>                return 0;
>        }
>
> @@ -536,8 +525,7 @@ static int sd_set_bus_speed_mode(struct mmc_card *card, u8 *status)
>                return err;
>
>        if ((status[16] & 0xF) != card->sd_bus_speed)
> -               pr_warn("%s: problem setting bus speed mode!\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "problem setting bus speed mode!\n");
>        else {
>                mmc_set_timing(card->host, timing);
>                mmc_set_clock(card->host, card->sw_caps.uhs_max_dtr);
> @@ -598,8 +586,7 @@ static int sd_set_current_limit(struct mmc_card *card, u8 *status)
>                return err;
>
>        if (((status[15] >> 4) & 0x0F) != current_limit)
> -               pr_warn("%s: problem setting current limit!\n",
> -                       mmc_hostname(card->host));
> +               mmc_host_warn(card->host, "problem setting current limit!\n");
>
>        return 0;
>  }
> @@ -620,8 +607,7 @@ static int mmc_sd_init_uhs_card(struct mmc_card *card)
>
>        status = kmalloc(64, GFP_KERNEL);
>        if (!status) {
> -               pr_err("%s: could not allocate a buffer for switch capabilities\n",
> -                      mmc_hostname(card->host));
> +               mmc_host_err(card->host, "could not allocate a buffer for switch capabilities\n");
>                return -ENOMEM;
>        }
>
> @@ -850,8 +836,7 @@ int mmc_sd_setup_card(struct mmc_host *host, struct mmc_card *card,
>                        ro = host->ops->get_ro(host);
>
>                if (ro < 0) {
> -                       pr_warn("%s: host does not support reading read-only switch. assuming write-enable.\n",
> -                               mmc_hostname(host));
> +                       mmc_host_warn(host, "host does not support reading read-only switch. assuming write-enable.\n");
>                } else if (ro > 0) {
>                        mmc_card_set_readonly(card);
>                }
> @@ -1162,15 +1147,13 @@ int mmc_attach_sd(struct mmc_host *host)
>         * support.
>         */
>        if (ocr & 0x7F) {
> -               pr_warn("%s: card claims to support voltages below the defined range. These will be ignored.\n",
> -                       mmc_hostname(host));
> +               mmc_host_warn(host, "card claims to support voltages below the defined range. These will be ignored.\n");
>                ocr &= ~0x7F;
>        }
>
>        if ((ocr & MMC_VDD_165_195) &&
>            !(host->ocr_avail_sd & MMC_VDD_165_195)) {
> -               pr_warn("%s: SD card claims to support the incompletely defined 'low voltage range'. This will be ignored.\n",
> -                       mmc_hostname(host));
> +               mmc_host_warn(host, "SD card claims to support the incompletely defined 'low voltage range'. This will be ignored.\n");
>                ocr &= ~MMC_VDD_165_195;
>        }
>
> @@ -1207,8 +1190,7 @@ remove_card:
>  err:
>        mmc_detach_bus(host);
>
> -       pr_err("%s: error %d whilst initialising SD card\n",
> -               mmc_hostname(host), err);
> +       mmc_host_err(host, "error %d whilst initialising SD card\n", err);
>
>        return err;
>  }
> diff --git a/drivers/mmc/core/sdio.c b/drivers/mmc/core/sdio.c
> index e994a89..7bae59b 100644
> --- a/drivers/mmc/core/sdio.c
> +++ b/drivers/mmc/core/sdio.c
> @@ -112,8 +112,8 @@ static int sdio_read_cccr(struct mmc_card *card)
>        cccr_vsn = data & 0x0f;
>
>        if (cccr_vsn > SDIO_CCCR_REV_3_00) {
> -               pr_err("%s: unrecognised CCCR structure version %d\n",
> -                       mmc_hostname(card->host), cccr_vsn);
> +               mmc_host_err(card->host, "unrecognised CCCR structure version %d\n",
> +                            cccr_vsn);
>                return -EINVAL;
>        }
>
> @@ -777,8 +777,7 @@ int mmc_attach_sdio(struct mmc_host *host)
>         * support.
>         */
>        if (ocr & 0x7F) {
> -               pr_warn("%s: card claims to support voltages below the defined range. These will be ignored.\n",
> -                       mmc_hostname(host));
> +               mmc_host_warn(host, "card claims to support voltages below the defined range. These will be ignored.\n");
>                ocr &= ~0x7F;
>        }
>
> @@ -873,8 +872,7 @@ remove:
>  err:
>        mmc_detach_bus(host);
>
> -       pr_err("%s: error %d whilst initialising SDIO card\n",
> -               mmc_hostname(host), err);
> +       mmc_host_err(host, "error %d whilst initialising SDIO card\n", err);
>
>        return err;
>  }
> diff --git a/drivers/mmc/core/sdio_cis.c b/drivers/mmc/core/sdio_cis.c
> index 6536fce..e50fecb 100644
> --- a/drivers/mmc/core/sdio_cis.c
> +++ b/drivers/mmc/core/sdio_cis.c
> @@ -132,8 +132,8 @@ static int cis_tpl_parse(struct mmc_card *card, struct sdio_func *func,
>                        ret = -EINVAL;
>                }
>                if (ret && ret != -EILSEQ && ret != -ENOENT) {
> -                       pr_err("%s: bad %s tuple 0x%02x (%u bytes)\n",
> -                              mmc_hostname(card->host), tpl_descr, code, size);
> +                       mmc_host_err(card->host, "bad %s tuple 0x%02x (%u bytes)\n",
> +                                    tpl_descr, code, size);
>                }
>        } else {
>                /* unknown tuple */
> @@ -313,9 +313,8 @@ static int sdio_read_cis(struct mmc_card *card, struct sdio_func *func)
>
>                        if (ret == -ENOENT) {
>                                /* warn about unknown tuples */
> -                               pr_warn("%s: queuing unknown CIS tuple 0x%02x (%u bytes)\n",
> -                                       mmc_hostname(card->host),
> -                                       tpl_code, tpl_link);
> +                               mmc_host_warn(card->host, "queuing unknown CIS tuple 0x%02x (%u bytes)\n",
> +                                             tpl_code, tpl_link);
>                        }
>
>                        /* keep on analyzing tuples */
> diff --git a/drivers/mmc/core/sdio_irq.c b/drivers/mmc/core/sdio_irq.c
> index 533d0e5..3aa13bf 100644
> --- a/drivers/mmc/core/sdio_irq.c
> +++ b/drivers/mmc/core/sdio_irq.c
> @@ -97,8 +97,8 @@ static int sdio_irq_thread(void *_host)
>        period = (host->caps & MMC_CAP_SDIO_IRQ) ?
>                MAX_SCHEDULE_TIMEOUT : idle_period;
>
> -       pr_debug("%s: IRQ thread started (poll period = %lu jiffies)\n",
> -                mmc_hostname(host), period);
> +       mmc_host_debug(host, "IRQ thread started (poll period = %lu jiffies)\n",
> +                      period);
>
>        do {
>                /*
> @@ -157,8 +157,7 @@ static int sdio_irq_thread(void *_host)
>        if (host->caps & MMC_CAP_SDIO_IRQ)
>                host->ops->enable_sdio_irq(host, 0);
>
> -       pr_debug("%s: IRQ thread exiting with code %d\n",
> -                mmc_hostname(host), ret);
> +       mmc_host_debug(host, "IRQ thread exiting with code %d\n", ret);
>
>        return ret;
>  }
> diff --git a/drivers/mmc/host/at91_mci.c b/drivers/mmc/host/at91_mci.c
> index d63f453..4add419 100644
> --- a/drivers/mmc/host/at91_mci.c
> +++ b/drivers/mmc/host/at91_mci.c
> @@ -881,8 +881,8 @@ static irqreturn_t at91_mmc_det_irq(int irq, void *_host)
>         */
>        if (present != host->present) {
>                host->present = present;
> -               pr_debug("%s: card %s\n", mmc_hostname(host->mmc),
> -                       present ? "insert" : "remove");
> +               mmc_host_debug(host->mmc, "card %s\n",
> +                              present ? "insert" : "remove");
>                if (!present) {
>                        pr_debug("****** Resetting SD-card bus width ******\n");
>                        at91_mci_write(host, AT91_MCI_SDCR, at91_mci_read(host, AT91_MCI_SDCR) & ~AT91_MCI_SDCBUS);
> @@ -910,8 +910,9 @@ static void at91_mci_enable_sdio_irq(struct mmc_host *mmc, int enable)
>  {
>        struct at91mci_host *host = mmc_priv(mmc);
>
> -       pr_debug("%s: sdio_irq %c : %s\n", mmc_hostname(host->mmc),
> -               host->board->slot_b ? 'B':'A', enable ? "enable" : "disable");
> +       mmc_host_debug(host->mmc, "sdio_irq %c : %s\n",
> +                      host->board->slot_b ? 'B' : 'A',
> +                      enable ? "enable" : "disable");
>        at91_mci_write(host, enable ? AT91_MCI_IER : AT91_MCI_IDR,
>                host->board->slot_b ? AT91_MCI_SDIOIRQB : AT91_MCI_SDIOIRQA);
>
> diff --git a/drivers/mmc/host/dw_mmc.c b/drivers/mmc/host/dw_mmc.c
> index 5d34c01..b4efd3c 100644
> --- a/drivers/mmc/host/dw_mmc.c
> +++ b/drivers/mmc/host/dw_mmc.c
> @@ -1712,7 +1712,7 @@ static int __init dw_mci_init_slot(struct dw_mci *host, unsigned int id)
>
>        host->vmmc = regulator_get(mmc_dev(mmc), "vmmc");
>        if (IS_ERR(host->vmmc)) {
> -               pr_info("%s: no vmmc regulator found\n", mmc_hostname(mmc));
> +               mmc_host_info(mmc, "no vmmc regulator found\n");
>                host->vmmc = NULL;
>        } else
>                regulator_enable(host->vmmc);
> diff --git a/drivers/mmc/host/msm_sdcc.c b/drivers/mmc/host/msm_sdcc.c
> index 80d8eb1..e0b49ec 100644
> --- a/drivers/mmc/host/msm_sdcc.c
> +++ b/drivers/mmc/host/msm_sdcc.c
> @@ -141,16 +141,15 @@ static void msmsdcc_reset_and_restore(struct msmsdcc_host *host)
>        /* Reset the controller */
>        ret = clk_reset(host->clk, CLK_RESET_ASSERT);
>        if (ret)
> -               pr_err("%s: Clock assert failed at %u Hz with err %d\n",
> -                               mmc_hostname(host->mmc), host->clk_rate, ret);
> +               mmc_host_err(host->mmc, "Clock assert failed at %u Hz with err %d\n",
> +                            host->clk_rate, ret);
>
>        ret = clk_reset(host->clk, CLK_RESET_DEASSERT);
>        if (ret)
> -               pr_err("%s: Clock deassert failed at %u Hz with err %d\n",
> -                               mmc_hostname(host->mmc), host->clk_rate, ret);
> +               mmc_host_err(host->mmc, "Clock deassert failed at %u Hz with err %d\n",
> +                            host->clk_rate, ret);
>
> -       pr_info("%s: Controller has been re-initialiazed\n",
> -                       mmc_hostname(host->mmc));
> +       mmc_host_info(host->mmc, "Controller has been re-initialized\n");
>
>        /* Restore the contoller state */
>        writel(host->pwr, host->base + MMCIPOWER);
> @@ -158,8 +157,8 @@ static void msmsdcc_reset_and_restore(struct msmsdcc_host *host)
>        writel(mci_mask0, host->base + MMCIMASK0);
>        ret = clk_set_rate(host->clk, host->clk_rate);
>        if (ret)
> -               pr_err("%s: Failed to set clk rate %u Hz (%d)\n",
> -                               mmc_hostname(host->mmc), host->clk_rate, ret);
> +               mmc_host_err(host->mmc, "Failed to set clk rate %u Hz (%d)\n",
> +                            host->clk_rate, ret);
>  }
>
>  static void
> @@ -251,11 +250,11 @@ msmsdcc_dma_complete_tlet(unsigned long data)
>        } else {
>                /* Error or flush  */
>                if (host->dma.result & DMOV_RSLT_ERROR)
> -                       pr_err("%s: DMA error (0x%.8x)\n",
> -                              mmc_hostname(host->mmc), host->dma.result);
> +                       mmc_host_err(host->mmc, "DMA error (0x%.8x)\n",
> +                                    host->dma.result);
>                if (host->dma.result & DMOV_RSLT_FLUSH)
> -                       pr_err("%s: DMA channel flushed (0x%.8x)\n",
> -                              mmc_hostname(host->mmc), host->dma.result);
> +                       mmc_host_err(host->mmc, "DMA channel flushed (0x%.8x)\n",
> +                                    host->dma.result);
>
>                pr_err("Flush data: %.8x %.8x %.8x %.8x %.8x %.8x\n",
>                       err.flush[0], err.flush[1], err.flush[2],
> @@ -389,8 +388,7 @@ static int msmsdcc_config_dma(struct msmsdcc_host *host, struct mmc_data *data)
>        n = dma_map_sg(mmc_dev(host->mmc), host->dma.sg,
>                        host->dma.num_ents, host->dma.dir);
>        if (n == 0) {
> -               pr_err("%s: Unable to map in all sg elements\n",
> -                       mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Unable to map in all sg elements\n");
>                host->dma.sg = NULL;
>                host->dma.num_ents = 0;
>                return -ENOMEM;
> @@ -475,8 +473,7 @@ msmsdcc_start_command_deferred(struct msmsdcc_host *host,
>                *c |= MCI_CSPM_MCIABORT;
>
>        if (host->curr.cmd != NULL) {
> -               pr_err("%s: Overlapping command requests\n",
> -                       mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Overlapping command requests\n");
>        }
>        host->curr.cmd = cmd;
>  }
> @@ -573,24 +570,23 @@ msmsdcc_data_err(struct msmsdcc_host *host, struct mmc_data *data,
>                 unsigned int status)
>  {
>        if (status & MCI_DATACRCFAIL) {
> -               pr_err("%s: Data CRC error\n", mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Data CRC error\n");
>                pr_err("%s: opcode 0x%.8x\n", __func__,
>                       data->mrq->cmd->opcode);
>                pr_err("%s: blksz %d, blocks %d\n", __func__,
>                       data->blksz, data->blocks);
>                data->error = -EILSEQ;
>        } else if (status & MCI_DATATIMEOUT) {
> -               pr_err("%s: Data timeout\n", mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Data timeout\n");
>                data->error = -ETIMEDOUT;
>        } else if (status & MCI_RXOVERRUN) {
> -               pr_err("%s: RX overrun\n", mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "RX overrun\n");
>                data->error = -EIO;
>        } else if (status & MCI_TXUNDERRUN) {
> -               pr_err("%s: TX underrun\n", mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "TX underrun\n");
>                data->error = -EIO;
>        } else {
> -               pr_err("%s: Unknown error (0x%.8x)\n",
> -                      mmc_hostname(host->mmc), status);
> +               mmc_host_err(host->mmc, "Unknown error (0x%.8x)\n", status);
>                data->error = -EIO;
>        }
>  }
> @@ -751,7 +747,7 @@ static void msmsdcc_do_cmdirq(struct msmsdcc_host *host, uint32_t status)
>                cmd->error = -ETIMEDOUT;
>        } else if (status & MCI_CMDCRCFAIL &&
>                   cmd->flags & MMC_RSP_CRC) {
> -               pr_err("%s: Command CRC error\n", mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Command CRC error\n");
>                cmd->error = -EILSEQ;
>        }
>
> @@ -960,10 +956,9 @@ static void msmsdcc_setup_gpio(struct msmsdcc_host *host, bool enable)
>                        rc = gpio_request(curr->gpio[i].no,
>                                                curr->gpio[i].name);
>                        if (rc) {
> -                               pr_err("%s: gpio_request(%d, %s) failed %d\n",
> -                                       mmc_hostname(host->mmc),
> -                                       curr->gpio[i].no,
> -                                       curr->gpio[i].name, rc);
> +                               mmc_host_err(host->mmc, "gpio_request(%d, %s) failed %d\n",
> +                                            curr->gpio[i].no,
> +                                            curr->gpio[i].name, rc);
>                                goto free_gpios;
>                        }
>                } else {
> @@ -996,8 +991,8 @@ msmsdcc_set_ios(struct mmc_host *mmc, struct mmc_ios *ios)
>                if (ios->clock != host->clk_rate) {
>                        rc = clk_set_rate(host->clk, ios->clock);
>                        if (rc < 0)
> -                               pr_err("%s: Error setting clock rate (%d)\n",
> -                                      mmc_hostname(host->mmc), rc);
> +                               mmc_host_err(host->mmc, "Error setting clock rate (%d)\n",
> +                                            rc);
>                        else
>                                host->clk_rate = ios->clock;
>                }
> @@ -1093,8 +1088,8 @@ msmsdcc_check_status(unsigned long data)
>        status = host->plat->status(mmc_dev(host->mmc));
>        host->eject = !status;
>        if (status ^ host->oldstat) {
> -               pr_info("%s: Slot status change detected (%d -> %d)\n",
> -                       mmc_hostname(host->mmc), host->oldstat, status);
> +               mmc_host_info(host->mmc, "Slot status change detected (%d -> %d)\n",
> +                             host->oldstat, status);
>                if (status)
>                        mmc_detect_change(host->mmc, (5 * HZ) / 2);
>                else
> @@ -1123,8 +1118,7 @@ msmsdcc_status_notify_cb(int card_present, void *dev_id)
>  {
>        struct msmsdcc_host *host = dev_id;
>
> -       pr_debug("%s: card_present %d\n", mmc_hostname(host->mmc),
> -              card_present);
> +       mmc_host_debug(host->mmc, "card_present %d\n", card_present);
>        msmsdcc_check_status((unsigned long) host);
>  }
>
> @@ -1321,15 +1315,14 @@ msmsdcc_probe(struct platform_device *pdev)
>                                  DRIVER_NAME " (slot)",
>                                  host);
>                if (ret) {
> -                       pr_err("%s: Unable to get slot IRQ %d (%d)\n",
> -                              mmc_hostname(mmc), host->stat_irq, ret);
> +                       mmc_host_err(mmc, "Unable to get slot IRQ %d (%d)\n",
> +                                    host->stat_irq, ret);
>                        goto clk_disable;
>                }
>        } else if (plat->register_status_notify) {
>                plat->register_status_notify(msmsdcc_status_notify_cb, host);
>        } else if (!plat->status)
> -               pr_err("%s: No card detect facilities available\n",
> -                      mmc_hostname(mmc));
> +               mmc_host_err(mmc, "No card detect facilities available\n");
>        else {
>                init_timer(&host->timer);
>                host->timer.data = (unsigned long)host;
> @@ -1356,28 +1349,26 @@ msmsdcc_probe(struct platform_device *pdev)
>        mmc_set_drvdata(pdev, mmc);
>        mmc_add_host(mmc);
>
> -       pr_info("%s: Qualcomm MSM SDCC at 0x%016llx irq %d,%d dma %d\n",
> -               mmc_hostname(mmc), (unsigned long long)memres->start,
> -               (unsigned int) cmd_irqres->start,
> -               (unsigned int) host->stat_irq, host->dma.channel);
> -       pr_info("%s: 4 bit data mode %s\n", mmc_hostname(mmc),
> -               (mmc->caps & MMC_CAP_4_BIT_DATA ? "enabled" : "disabled"));
> -       pr_info("%s: MMC clock %u -> %u Hz, PCLK %u Hz\n",
> -               mmc_hostname(mmc), msmsdcc_fmin, msmsdcc_fmax, host->pclk_rate);
> -       pr_info("%s: Slot eject status = %d\n", mmc_hostname(mmc), host->eject);
> -       pr_info("%s: Power save feature enable = %d\n",
> -               mmc_hostname(mmc), msmsdcc_pwrsave);
> +       mmc_host_info(mmc, "Qualcomm MSM SDCC at 0x%016llx irq %d,%d dma %d\n",
> +                     (unsigned long long)memres->start,
> +                     (unsigned int) cmd_irqres->start,
> +                     (unsigned int) host->stat_irq, host->dma.channel);
> +       mmc_host_info(mmc, "4 bit data mode %s\n",
> +                     mmc->caps & MMC_CAP_4_BIT_DATA ? "enabled" : "disabled");
> +       mmc_host_info(mmc, "MMC clock %u -> %u Hz, PCLK %u Hz\n",
> +                     msmsdcc_fmin, msmsdcc_fmax, host->pclk_rate);
> +       mmc_host_info(mmc, "Slot eject status = %d\n", host->eject);
> +       mmc_host_info(mmc, "Power save feature enable = %d\n", msmsdcc_pwrsave);
>
>        if (host->dma.channel != -1) {
> -               pr_info("%s: DM non-cached buffer at %p, dma_addr 0x%.8x\n",
> -                       mmc_hostname(mmc), host->dma.nc, host->dma.nc_busaddr);
> -               pr_info("%s: DM cmd busaddr 0x%.8x, cmdptr busaddr 0x%.8x\n",
> -                       mmc_hostname(mmc), host->dma.cmd_busaddr,
> -                       host->dma.cmdptr_busaddr);
> +               mmc_host_info(mmc, "DM non-cached buffer at %p, dma_addr 0x%.8x\n",
> +                             host->dma.nc, host->dma.nc_busaddr);
> +               mmc_host_info(mmc, "DM cmd busaddr 0x%.8x, cmdptr busaddr 0x%.8x\n",
> +                             host->dma.cmd_busaddr, host->dma.cmdptr_busaddr);
>        } else
> -               pr_info("%s: PIO transfer enabled\n", mmc_hostname(mmc));
> +               mmc_host_info(mmc, "PIO transfer enabled\n");
>        if (host->timer.function)
> -               pr_info("%s: Polling status mode enabled\n", mmc_hostname(mmc));
> +               mmc_host_info(mmc, "Polling status mode enabled\n");
>
>        return 0;
>  cmd_irq_free:
> diff --git a/drivers/mmc/host/mvsdio.c b/drivers/mmc/host/mvsdio.c
> index 93012a0..7928e2e 100644
> --- a/drivers/mmc/host/mvsdio.c
> +++ b/drivers/mmc/host/mvsdio.c
> @@ -117,9 +117,8 @@ static int mvsd_setup_data(struct mvsd_host *host, struct mmc_data *data)
>                host->pio_size = data->blocks * data->blksz;
>                host->pio_ptr = sg_virt(data->sg);
>                if (!nodma)
> -                       pr_debug("%s: fallback to PIO for data at 0x%p size %d\n",
> -                                mmc_hostname(host->mmc),
> -                                host->pio_ptr, host->pio_size);
> +                       mmc_host_debug(host->mmc, "fallback to PIO for data at 0x%p size %d\n",
> +                                      host->pio_ptr, host->pio_size);
>                return 1;
>        } else {
>                dma_addr_t phys_addr;
> @@ -470,8 +469,8 @@ static irqreturn_t mvsd_irq(int irq, void *dev)
>                if (mrq->data)
>                        err_status = mvsd_finish_data(host, mrq->data, err_status);
>                if (err_status) {
> -                       pr_err("%s: unhandled error status %#04x\n",
> -                                       mmc_hostname(host->mmc), err_status);
> +                       mmc_host_err(host->mmc, "unhandled error status %#04x\n",
> +                                    err_status);
>                        cmd->error = -ENOMSG;
>                }
>
> @@ -488,9 +487,8 @@ static irqreturn_t mvsd_irq(int irq, void *dev)
>        if (irq_handled)
>                return IRQ_HANDLED;
>
> -       pr_err("%s: unhandled interrupt status=0x%04x en=0x%04x pio=%d\n",
> -              mmc_hostname(host->mmc), intr_status,
> -              host->intr_en, host->pio_size);
> +       mmc_host_err(host->mmc, "unhandled interrupt status=0x%04x en=0x%04x pio=%d\n",
> +                    intr_status, host->intr_en, host->pio_size);
>        return IRQ_NONE;
>  }
>
> @@ -504,13 +502,11 @@ static void mvsd_timeout_timer(unsigned long data)
>        spin_lock_irqsave(&host->lock, flags);
>        mrq = host->mrq;
>        if (mrq) {
> -               pr_err("%s: Timeout waiting for hardware interrupt\n",
> -                      mmc_hostname(host->mmc));
> -               pr_err("%s: hw_state=0x%04x, intr_status=0x%04x intr_en=0x%04x\n",
> -                      mmc_hostname(host->mmc),
> -                      mvsd_read(MVSD_HW_STATE),
> -                      mvsd_read(MVSD_NOR_INTR_STATUS),
> -                      mvsd_read(MVSD_NOR_INTR_EN));
> +               mmc_host_err(host->mmc, "Timeout waiting for hardware interrupt\n");
> +               mmc_host_err(host->mmc, "hw_state=0x%04x, intr_status=0x%04x intr_en=0x%04x\n",
> +                            mvsd_read(MVSD_HW_STATE),
> +                            mvsd_read(MVSD_NOR_INTR_STATUS),
> +                            mvsd_read(MVSD_NOR_INTR_EN));
>
>                host->mrq = NULL;
>
> @@ -801,13 +797,12 @@ static int __init mvsd_probe(struct platform_device *pdev)
>        if (ret)
>                goto out;
>
> -       pr_notice("%s: %s driver initialized, ",
> -                          mmc_hostname(mmc), DRIVER_NAME);
> +       mmc_host_notice(mmc, "%s driver initialized, ", DRIVER_NAME);
>        if (host->gpio_card_detect)
> -               printk("using GPIO %d for card detection\n",
> -                      host->gpio_card_detect);
> +               pr_cont("using GPIO %d for card detection\n",
> +                       host->gpio_card_detect);
>        else
> -               printk("lacking card detect (fall back to polling)\n");
> +               pr_cont("lacking card detect (fall back to polling)\n");
>        return 0;
>
>  out:
> diff --git a/drivers/mmc/host/omap_hsmmc.c b/drivers/mmc/host/omap_hsmmc.c
> index dd5159b..35bddef 100644
> --- a/drivers/mmc/host/omap_hsmmc.c
> +++ b/drivers/mmc/host/omap_hsmmc.c
> @@ -1264,15 +1264,12 @@ static void omap_hsmmc_protect_card(struct omap_hsmmc_host *host)
>        host->reqs_blocked = 0;
>        if (mmc_slot(host).get_cover_state(host->dev, host->slot_id)) {
>                if (host->protect_card) {
> -                       pr_info("%s: cover is closed, card is now accessible\n",
> -                               mmc_hostname(host->mmc));
> +                       mmc_host_info(host->mmc, "cover is closed, card is now accessible\n");
>                        host->protect_card = 0;
>                }
>        } else {
>                if (!host->protect_card) {
> -                       pr_info("%s: cover is open, "
> -                                        "card is now inaccessible\n",
> -                                        mmc_hostname(host->mmc));
> +                       mmc_host_info(host->mmc, "cover is open, card is now inaccessible\n");
>                        host->protect_card = 1;
>                }
>        }
> diff --git a/drivers/mmc/host/pxamci.c b/drivers/mmc/host/pxamci.c
> index fc4356e..f8c6df2 100644
> --- a/drivers/mmc/host/pxamci.c
> +++ b/drivers/mmc/host/pxamci.c
> @@ -558,8 +558,8 @@ static void pxamci_dma_irq(int dma, void *devid)
>        if (dcsr & DCSR_ENDINTR) {
>                writel(BUF_PART_FULL, host->base + MMC_PRTBUF);
>        } else {
> -               pr_err("%s: DMA error on channel %d (DCSR=%#x)\n",
> -                      mmc_hostname(host->mmc), dma, dcsr);
> +               mmc_host_err(host->mmc, "DMA error on channel %d (DCSR=%#x)\n",
> +                            dma, dcsr);
>                host->data->error = -EIO;
>                pxamci_data_done(host, 0);
>        }
> diff --git a/drivers/mmc/host/sdhci.c b/drivers/mmc/host/sdhci.c
> index d31c31d..3fcf79d 100644
> --- a/drivers/mmc/host/sdhci.c
> +++ b/drivers/mmc/host/sdhci.c
> @@ -202,8 +202,8 @@ static void sdhci_reset(struct sdhci_host *host, u8 mask)
>        /* hw clears the bit when it's done */
>        while (sdhci_readb(host, SDHCI_SOFTWARE_RESET) & mask) {
>                if (timeout == 0) {
> -                       pr_err("%s: Reset 0x%x never completed.\n",
> -                               mmc_hostname(host->mmc), (int)mask);
> +                       mmc_host_err(host->mmc, "Reset 0x%x never completed\n",
> +                                    (int)mask);
>                        sdhci_dumpregs(host);
>                        return;
>                }
> @@ -679,8 +679,8 @@ static u8 sdhci_calc_timeout(struct sdhci_host *host, struct mmc_command *cmd)
>        }
>
>        if (count >= 0xF) {
> -               pr_warn("%s: Too large timeout requested for CMD%d!\n",
> -                       mmc_hostname(host->mmc), cmd->opcode);
> +               mmc_host_warn(host->mmc, "Too large timeout requested for CMD%d!\n",
> +                             cmd->opcode);
>                count = 0xE;
>        }
>
> @@ -972,8 +972,7 @@ static void sdhci_send_command(struct sdhci_host *host, struct mmc_command *cmd)
>
>        while (sdhci_readl(host, SDHCI_PRESENT_STATE) & mask) {
>                if (timeout == 0) {
> -                       pr_err("%s: Controller never released inhibit bit(s)\n",
> -                              mmc_hostname(host->mmc));
> +                       mmc_host_err(host->mmc, "Controller never released inhibit bit(s)\n");
>                        sdhci_dumpregs(host);
>                        cmd->error = -EIO;
>                        tasklet_schedule(&host->finish_tasklet);
> @@ -994,8 +993,7 @@ static void sdhci_send_command(struct sdhci_host *host, struct mmc_command *cmd)
>        sdhci_set_transfer_mode(host, cmd);
>
>        if ((cmd->flags & MMC_RSP_136) && (cmd->flags & MMC_RSP_BUSY)) {
> -               pr_err("%s: Unsupported response type!\n",
> -                       mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Unsupported response type!\n");
>                cmd->error = -EINVAL;
>                tasklet_schedule(&host->finish_tasklet);
>                return;
> @@ -1154,8 +1152,7 @@ static void sdhci_set_clock(struct sdhci_host *host, unsigned int clock)
>        while (!((clk = sdhci_readw(host, SDHCI_CLOCK_CONTROL))
>                & SDHCI_CLOCK_INT_STABLE)) {
>                if (timeout == 0) {
> -                       pr_err("%s: Internal clock never stabilised\n",
> -                              mmc_hostname(host->mmc));
> +                       mmc_host_err(host->mmc, "Internal clock never stabilised\n");
>                        sdhci_dumpregs(host);
>                        return;
>                }
> @@ -1912,10 +1909,8 @@ static void sdhci_tasklet_card(unsigned long param)
>        /* Check host->mrq first in case we are runtime suspended */
>        if (host->mrq &&
>            !(sdhci_readl(host, SDHCI_PRESENT_STATE) & SDHCI_CARD_PRESENT)) {
> -               pr_err("%s: Card removed during transfer!\n",
> -                       mmc_hostname(host->mmc));
> -               pr_err("%s: Resetting controller.\n",
> -                       mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Card removed during transfer!\n");
> +               mmc_host_err(host->mmc, "Resetting controller.\n");
>
>                sdhci_reset(host, SDHCI_RESET_CMD);
>                sdhci_reset(host, SDHCI_RESET_DATA);
> @@ -2003,8 +1998,7 @@ static void sdhci_timeout_timer(unsigned long data)
>        spin_lock_irqsave(&host->lock, flags);
>
>        if (host->mrq) {
> -               pr_err("%s: Timeout waiting for hardware interrupt\n",
> -                      mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Timeout waiting for hardware interrupt\n");
>                sdhci_dumpregs(host);
>
>                if (host->data) {
> @@ -2049,8 +2043,8 @@ static void sdhci_cmd_irq(struct sdhci_host *host, u32 intmask)
>        BUG_ON(intmask == 0);
>
>        if (!host->cmd) {
> -               pr_err("%s: Got command interrupt 0x%08x even though no command operation was in progress\n",
> -                      mmc_hostname(host->mmc), (unsigned)intmask);
> +               mmc_host_err(host->mmc, "Got command interrupt 0x%08x even though no command operation was in progress\n",
> +                            (unsigned)intmask);
>                sdhci_dumpregs(host);
>                return;
>        }
> @@ -2147,8 +2141,8 @@ static void sdhci_data_irq(struct sdhci_host *host, u32 intmask)
>                        }
>                }
>
> -               pr_err("%s: Got data interrupt 0x%08x even though no data operation was in progress\n",
> -                      mmc_hostname(host->mmc), (unsigned)intmask);
> +               mmc_host_err(host->mmc, "Got data interrupt 0x%08x even though no data operation was in progress\n",
> +                            (unsigned)intmask);
>                sdhci_dumpregs(host);
>
>                return;
> @@ -2163,7 +2157,7 @@ static void sdhci_data_irq(struct sdhci_host *host, u32 intmask)
>                        != MMC_BUS_TEST_R)
>                host->data->error = -EILSEQ;
>        else if (intmask & SDHCI_INT_ADMA_ERROR) {
> -               pr_err("%s: ADMA error\n", mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "ADMA error\n");
>                sdhci_show_adma_error(host);
>                host->data->error = -EIO;
>        }
> @@ -2226,8 +2220,7 @@ static irqreturn_t sdhci_irq(int irq, void *dev_id)
>
>        if (host->runtime_suspended) {
>                spin_unlock(&host->lock);
> -               pr_warn("%s: got irq while runtime suspended\n",
> -                       mmc_hostname(host->mmc));
> +               mmc_host_warn(host->mmc, "got irq while runtime suspended\n");
>                return IRQ_HANDLED;
>        }
>
> @@ -2283,8 +2276,7 @@ static irqreturn_t sdhci_irq(int irq, void *dev_id)
>        intmask &= ~SDHCI_INT_ERROR;
>
>        if (intmask & SDHCI_INT_BUS_POWER) {
> -               pr_err("%s: Card is consuming too much power!\n",
> -                       mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "Card is consuming too much power!\n");
>                sdhci_writel(host, SDHCI_INT_BUS_POWER, SDHCI_INT_STATUS);
>        }
>
> @@ -2296,8 +2288,8 @@ static irqreturn_t sdhci_irq(int irq, void *dev_id)
>        intmask &= ~SDHCI_INT_CARD_INT;
>
>        if (intmask) {
> -               pr_err("%s: Unexpected interrupt 0x%08x.\n",
> -                       mmc_hostname(host->mmc), intmask);
> +               mmc_host_err(host->mmc, "Unexpected interrupt 0x%08x\n",
> +                            intmask);
>                sdhci_dumpregs(host);
>
>                sdhci_writel(host, intmask, SDHCI_INT_STATUS);
> @@ -2537,8 +2529,8 @@ int sdhci_add_host(struct sdhci_host *host)
>        host->version = (host->version & SDHCI_SPEC_VER_MASK)
>                                >> SDHCI_SPEC_VER_SHIFT;
>        if (host->version > SDHCI_SPEC_300) {
> -               pr_err("%s: Unknown controller version (%d). You may experience problems.\n",
> -                      mmc_hostname(mmc), host->version);
> +               mmc_host_err(mmc, "Unknown controller version (%d). You may experience problems.\n",
> +                            host->version);
>        }
>
>        caps[0] = (host->quirks & SDHCI_QUIRK_MISSING_CAPS) ? host->caps :
> @@ -2573,8 +2565,7 @@ int sdhci_add_host(struct sdhci_host *host)
>        if (host->flags & (SDHCI_USE_SDMA | SDHCI_USE_ADMA)) {
>                if (host->ops->enable_dma) {
>                        if (host->ops->enable_dma(host)) {
> -                               pr_warn("%s: No suitable DMA available. Falling back to PIO.\n",
> -                                       mmc_hostname(mmc));
> +                               mmc_host_warn(mmc, "No suitable DMA available. Falling back to PIO.\n");
>                                host->flags &=
>                                        ~(SDHCI_USE_SDMA | SDHCI_USE_ADMA);
>                        }
> @@ -2592,8 +2583,7 @@ int sdhci_add_host(struct sdhci_host *host)
>                if (!host->adma_desc || !host->align_buffer) {
>                        kfree(host->adma_desc);
>                        kfree(host->align_buffer);
> -                       pr_warn("%s: Unable to allocate ADMA buffers. Falling back to standard DMA.\n",
> -                               mmc_hostname(mmc));
> +                       mmc_host_warn(mmc, "Unable to allocate ADMA buffers. Falling back to standard DMA.\n");
>                        host->flags &= ~SDHCI_USE_ADMA;
>                }
>        }
> @@ -2619,8 +2609,7 @@ int sdhci_add_host(struct sdhci_host *host)
>        if (host->max_clk == 0 || host->quirks &
>                        SDHCI_QUIRK_CAP_CLOCK_BASE_BROKEN) {
>                if (!host->ops->get_max_clock) {
> -                       pr_err("%s: Hardware doesn't specify base clock frequency\n",
> -                              mmc_hostname(mmc));
> +                       mmc_host_err(mmc, "Hardware doesn't specify base clock frequency\n");
>                        return -ENODEV;
>                }
>                host->max_clk = host->ops->get_max_clock(host);
> @@ -2665,8 +2654,7 @@ int sdhci_add_host(struct sdhci_host *host)
>                        host->timeout_clk = host->ops->get_timeout_clock(host);
>                } else if (!(host->quirks &
>                                SDHCI_QUIRK_DATA_TIMEOUT_USES_SDCLK)) {
> -                       pr_err("%s: Hardware doesn't specify timeout clock frequency\n",
> -                              mmc_hostname(mmc));
> +                       mmc_host_err(mmc, "Hardware doesn't specify timeout clock frequency\n");
>                        return -ENODEV;
>                }
>        }
> @@ -2833,8 +2821,7 @@ int sdhci_add_host(struct sdhci_host *host)
>                mmc->ocr_avail_mmc &= host->ocr_avail_mmc;
>
>        if (mmc->ocr_avail == 0) {
> -               pr_err("%s: Hardware doesn't report any support voltages\n",
> -                      mmc_hostname(mmc));
> +               mmc_host_err(mmc, "Hardware doesn't report any support voltages\n");
>                return -ENODEV;
>        }
>
> @@ -2881,8 +2868,7 @@ int sdhci_add_host(struct sdhci_host *host)
>                mmc->max_blk_size = (caps[0] & SDHCI_MAX_BLOCK_MASK) >>
>                                SDHCI_MAX_BLOCK_SHIFT;
>                if (mmc->max_blk_size >= 3) {
> -                       pr_warn("%s: Invalid maximum block size, assuming 512 bytes\n",
> -                               mmc_hostname(mmc));
> +                       mmc_host_warn(mmc, "Invalid maximum block size, assuming 512 bytes\n");
>                        mmc->max_blk_size = 0;
>                }
>        }
> @@ -2920,7 +2906,7 @@ int sdhci_add_host(struct sdhci_host *host)
>
>        host->vmmc = regulator_get(mmc_dev(mmc), "vmmc");
>        if (IS_ERR(host->vmmc)) {
> -               pr_info("%s: no vmmc regulator found\n", mmc_hostname(mmc));
> +               mmc_host_info(mmc, "no vmmc regulator found\n");
>                host->vmmc = NULL;
>        } else {
>                regulator_enable(host->vmmc);
> @@ -2949,10 +2935,10 @@ int sdhci_add_host(struct sdhci_host *host)
>
>        mmc_add_host(mmc);
>
> -       pr_info("%s: SDHCI controller on %s [%s] using %s\n",
> -               mmc_hostname(mmc), host->hw_name, dev_name(mmc_dev(mmc)),
> -               (host->flags & SDHCI_USE_ADMA) ? "ADMA" :
> -               (host->flags & SDHCI_USE_SDMA) ? "DMA" : "PIO");
> +       mmc_host_info(mmc, "SDHCI controller on %s [%s] using %s\n",
> +                     host->hw_name, dev_name(mmc_dev(mmc)),
> +                     (host->flags & SDHCI_USE_ADMA) ? "ADMA" :
> +                     (host->flags & SDHCI_USE_SDMA) ? "DMA" : "PIO");
>
>        sdhci_enable_card_detection(host);
>
> @@ -2982,8 +2968,7 @@ void sdhci_remove_host(struct sdhci_host *host, int dead)
>                host->flags |= SDHCI_DEVICE_DEAD;
>
>                if (host->mrq) {
> -                       pr_err("%s: Controller removed during transfer!\n",
> -                              mmc_hostname(host->mmc));
> +                       mmc_host_err(host->mmc, "Controller removed during transfer!\n");
>
>                        host->mrq->cmd->error = -ENOMEDIUM;
>                        tasklet_schedule(&host->finish_tasklet);
> diff --git a/drivers/mmc/host/tmio_mmc.c b/drivers/mmc/host/tmio_mmc.c
> index a4ea102..cfd45cb 100644
> --- a/drivers/mmc/host/tmio_mmc.c
> +++ b/drivers/mmc/host/tmio_mmc.c
> @@ -93,8 +93,8 @@ static int __devinit tmio_mmc_probe(struct platform_device *pdev)
>        if (ret)
>                goto host_remove;
>
> -       pr_info("%s at 0x%08lx irq %d\n", mmc_hostname(host->mmc),
> -               (unsigned long)host->ctl, irq);
> +       mmc_host_info(host->mmc, "at 0x%08lx irq %d\n",
> +                     (unsigned long)host->ctl, irq);
>
>        return 0;
>
> diff --git a/drivers/mmc/host/tmio_mmc_pio.c b/drivers/mmc/host/tmio_mmc_pio.c
> index d85a60c..ad680d7 100644
> --- a/drivers/mmc/host/tmio_mmc_pio.c
> +++ b/drivers/mmc/host/tmio_mmc_pio.c
> @@ -681,8 +681,8 @@ static int tmio_mmc_start_data(struct tmio_mmc_host *host,
>                int blksz_2bytes = pdata->flags & TMIO_MMC_BLKSZ_2BYTES;
>
>                if (data->blksz < 2 || (data->blksz < 4 && !blksz_2bytes)) {
> -                       pr_err("%s: %d byte block unsupported in 4 bit mode\n",
> -                              mmc_hostname(host->mmc), data->blksz);
> +                       mmc_host_err(host->mmc, "%d byte block unsupported in 4 bit mode\n",
> +                                    data->blksz);
>                        return -EINVAL;
>                }
>        }
> diff --git a/drivers/mmc/host/via-sdmmc.c b/drivers/mmc/host/via-sdmmc.c
> index dc479b0..a673161 100644
> --- a/drivers/mmc/host/via-sdmmc.c
> +++ b/drivers/mmc/host/via-sdmmc.c
> @@ -585,7 +585,7 @@ static void via_sdc_send_command(struct via_crdr_mmc_host *host,
>                cmdctrl |= VIA_CRDR_SDCTRL_RSP_R3;
>                break;
>        default:
> -               pr_err("%s: cmd->flag is not valid\n", mmc_hostname(host->mmc));
> +               mmc_host_err(host->mmc, "cmd->flag is not valid\n");
>                break;
>        }
>
> @@ -840,8 +840,8 @@ static void via_sdc_cmd_isr(struct via_crdr_mmc_host *host, u16 intmask)
>        BUG_ON(intmask == 0);
>
>        if (!host->cmd) {
> -               pr_err("%s: Got command interrupt 0x%x even though no command operation was in progress\n",
> -                      mmc_hostname(host->mmc), intmask);
> +               mmc_host_err(host->mmc, "Got command interrupt 0x%x even though no command operation was in progress\n",
> +                            intmask);
>                return;
>        }
>
> @@ -918,8 +918,8 @@ static irqreturn_t via_sdc_isr(int irq, void *dev_id)
>
>        sd_status &= ~(VIA_CRDR_SDSTS_CMD_MASK | VIA_CRDR_SDSTS_DATA_MASK);
>        if (sd_status) {
> -               pr_err("%s: Unexpected interrupt 0x%x\n",
> -                      mmc_hostname(sdhost->mmc), sd_status);
> +               mmc_host_err(sdhost->mmc, "Unexpected interrupt 0x%x\n",
> +                            sd_status);
>                writew(sd_status, addrbase + VIA_CRDR_SDSTATUS);
>        }
>
> @@ -942,9 +942,8 @@ static void via_sdc_timeout(unsigned long ulongdata)
>        spin_lock_irqsave(&sdhost->lock, flags);
>
>        if (sdhost->mrq) {
> -               pr_err("%s: Timeout waiting for hardware interrupt.cmd:0x%x\n",
> -                      mmc_hostname(sdhost->mmc),
> -                      sdhost->mrq->cmd->opcode);
> +               mmc_host_err(sdhost->mmc, "Timeout waiting for hardware interrupt.cmd:0x%x\n",
> +                            sdhost->mrq->cmd->opcode);
>
>                if (sdhost->data) {
>                        writel(VIA_CRDR_DMACTRL_SFTRST,
> @@ -1006,8 +1005,7 @@ static void via_sdc_card_detect(struct work_struct *work)
>        status = readw(addrbase + VIA_CRDR_SDSTATUS);
>        if (!(status & VIA_CRDR_SDSTS_SLOTG)) {
>                if (host->mrq) {
> -                       pr_err("%s: Card removed during transfer!\n",
> -                              mmc_hostname(host->mmc));
> +                       mmc_host_err(host->mmc, "Card removed during transfer!\n");
>                        host->mrq->cmd->error = -ENOMEDIUM;
>                        tasklet_schedule(&host->finish_tasklet);
>                }
> @@ -1192,8 +1190,7 @@ static void __devexit via_sd_remove(struct pci_dev *pcidev)
>        mmiowb();
>
>        if (sdhost->mrq) {
> -               pr_err("%s: Controller removed during transfer\n",
> -                      mmc_hostname(sdhost->mmc));
> +               mmc_host_err(sdhost->mmc, "Controller removed during transfer\n");
>
>                /* make sure all DMA is stopped */
>                writel(VIA_CRDR_DMACTRL_SFTRST,
> diff --git a/drivers/mmc/host/wbsd.c b/drivers/mmc/host/wbsd.c
> index 7536b50..ae474a4 100644
> --- a/drivers/mmc/host/wbsd.c
> +++ b/drivers/mmc/host/wbsd.c
> @@ -194,7 +194,7 @@ static void wbsd_reset(struct wbsd_host *host)
>  {
>        u8 setup;
>
> -       pr_err("%s: Resetting chip\n", mmc_hostname(host->mmc));
> +       mmc_host_err(host->mmc, "Resetting chip\n");
>
>        /*
>         * Soft reset of chip (SD/MMC part).
> @@ -721,8 +721,8 @@ static void wbsd_finish_data(struct wbsd_host *host, struct mmc_data *data)
>                 * Any leftover data?
>                 */
>                if (count) {
> -                       pr_err("%s: Incomplete DMA transfer. %d bytes left.\n",
> -                              mmc_hostname(host->mmc), count);
> +                       mmc_host_err(host->mmc, "Incomplete DMA transfer. %d bytes left.\n",
> +                                    count);
>
>                        if (!data->error)
>                                data->error = -EIO;
> @@ -802,8 +802,8 @@ static void wbsd_request(struct mmc_host *mmc, struct mmc_request *mrq)
>
>                default:
>  #ifdef CONFIG_MMC_DEBUG
> -                       pr_warn("%s: Data command %d is not supported by this controller\n",
> -                               mmc_hostname(host->mmc), cmd->opcode);
> +                       mmc_host_warn(host->mmc, "Data command %d is not supported by this controller\n",
> +                                     cmd->opcode);
>  #endif
>                        cmd->error = -EINVAL;
>
> @@ -1027,8 +1027,7 @@ static void wbsd_tasklet_card(unsigned long param)
>                host->flags &= ~WBSD_FCARD_PRESENT;
>
>                if (host->mrq) {
> -                       pr_err("%s: Card removed during transfer!\n",
> -                               mmc_hostname(host->mmc));
> +                       mmc_host_err(host->mmc, "Card removed during transfer!\n");
>                        wbsd_reset(host);
>
>                        host->mrq->cmd->error = -ENOMEDIUM;
> @@ -1713,17 +1712,17 @@ static int __devinit wbsd_init(struct device *dev, int base, int irq, int dma,
>
>        mmc_add_host(mmc);
>
> -       pr_info("%s: W83L51xD", mmc_hostname(mmc));
> +       mmc_host_info(mmc, "W83L51xD");
>        if (host->chip_id != 0)
> -               printk(" id %x", (int)host->chip_id);
> -       printk(" at 0x%x irq %d", (int)host->base, (int)host->irq);
> +               pr_cont(" id %x", (int)host->chip_id);
> +       pr_cont(" at 0x%x irq %d", (int)host->base, (int)host->irq);
>        if (host->dma >= 0)
> -               printk(" dma %d", (int)host->dma);
> +               pr_cont(" dma %d", (int)host->dma);
>        else
> -               printk(" FIFO");
> +               pr_cont(" FIFO");
>        if (pnp)
> -               printk(" PnP");
> -       printk("\n");
> +               pr_cont(" PnP");
> +       pr_cont("\n");
>
>        return 0;
>  }
> diff --git a/include/linux/mmc/host.h b/include/linux/mmc/host.h
> index 706f722..7483c7e 100644
> --- a/include/linux/mmc/host.h
> +++ b/include/linux/mmc/host.h
> @@ -335,6 +335,17 @@ extern int mmc_add_host(struct mmc_host *);
>  extern void mmc_remove_host(struct mmc_host *);
>  extern void mmc_free_host(struct mmc_host *);
>
> +#define mmc_host_err(mmc, fmt, ...)                            \
> +       pr_err("%s: " fmt, mmc_hostname(mmc), ##__VA_ARGS__)
> +#define mmc_host_warn(mmc, fmt, ...)                           \
> +       pr_warn("%s: " fmt, mmc_hostname(mmc), ##__VA_ARGS__)
> +#define mmc_host_notice(mmc, fmt, ...)                         \
> +       pr_notice("%s: " fmt, mmc_hostname(mmc), ##__VA_ARGS__)
> +#define mmc_host_info(mmc, fmt, ...)                           \
> +       pr_info("%s: " fmt, mmc_hostname(mmc), ##__VA_ARGS__)
> +#define mmc_host_debug(mmc, fmt, ...)                          \
> +       pr_debug("%s: " fmt, mmc_hostname(mmc), ##__VA_ARGS__)
> +
>  static inline void *mmc_priv(struct mmc_host *host)
>  {
>        return (void *)host->private;
> --
> 1.7.6.405.gc1be0
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@...r.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ