At Thu, 13 Sep 2012 18:15:56 -0700, Ian Minett wrote:
From: Ian Minett ian_minett@creativelabs.com
FWIW, the 3.7 kernel will have a firmware cache infrastructure, so this patch can be converted with it later.
BTW, what about the firmware loading upon PM resume? I guess at least S4 requires the firmware loading. Does the firmware on chip survive after S3?
Takashi
Signed-off-by: Ian Minett ian_minett@creativelabs.com
diff --git a/sound/pci/hda/patch_ca0132.c b/sound/pci/hda/patch_ca0132.c index 11f5910..ef66817 100644 --- a/sound/pci/hda/patch_ca0132.c +++ b/sound/pci/hda/patch_ca0132.c @@ -2025,6 +2025,24 @@ static int dspload_image(struct hda_codec *codec, return status; }
+static const struct firmware *fw_efx;
+static int request_firmware_cached(const struct firmware **firmware_p,
- const char *name, struct device *device)
+{
- if (*firmware_p)
return 0; /* already loaded */
- return request_firmware(firmware_p, name, device);
+}
+static void release_cached_firmware(void) +{
- if (fw_efx) {
release_firmware(fw_efx);
fw_efx = NULL;
- }
+}
static bool dspload_is_loaded(struct hda_codec *codec) { unsigned int data = 0; @@ -2542,18 +2560,15 @@ static bool ca0132_download_dsp_images(struct hda_codec *codec) { bool dsp_loaded = false; const struct dsp_image_seg *dsp_os_image;
const struct firmware *fw_entry;
if (request_firmware(&fw_entry, EFX_FILE, codec->bus->card->dev) != 0)
- if (request_firmware_cached(&fw_efx, EFX_FILE,
return false;codec->bus->card->dev) != 0)
- dsp_os_image = (struct dsp_image_seg *)(fw_entry->data);
- dsp_os_image = (struct dsp_image_seg *)(fw_efx->data); dspload_image(codec, dsp_os_image, 0, 0, true, 0); dsp_loaded = dspload_wait_loaded(codec);
- release_firmware(fw_entry);
- return dsp_loaded;
}
@@ -2662,7 +2677,8 @@ static int __init patch_ca0132_init(void) }
static void __exit patch_ca0132_exit(void) -{ +{
- release_cached_firmware(); snd_hda_delete_codec_preset(&ca0132_list);
}
-- 1.7.4.1