/* * oxfw_proc.c - a part of driver for OXFW970/971 based devices * * Copyright (c) 2014 Takashi Sakamoto * * Licensed under the terms of the GNU General Public License, version 2. */ #include "./oxfw.h" static void proc_read_formation(struct snd_info_entry *entry, struct snd_info_buffer *buffer) { struct snd_oxfw *oxfw = entry->private_data; struct snd_oxfw_stream_formation formation, curr; u8 *format; char flag; int i, err; /* Show input. */ err = snd_oxfw_stream_get_current_formation(oxfw, AVC_GENERAL_PLUG_DIR_IN, &curr); if (err < 0) return; snd_iprintf(buffer, "Input Stream to device:\n"); snd_iprintf(buffer, "\tRate\tPCM\tMIDI\n"); for (i = 0; i < SND_OXFW_STREAM_FORMAT_ENTRIES; i++) { format = oxfw->rx_stream_formats[i]; if (format == NULL) continue; err = snd_oxfw_stream_parse_format(format, &formation); if (err < 0) continue; if (memcmp(&formation, &curr, sizeof(curr)) == 0) flag = '*'; else flag = ' '; snd_iprintf(buffer, "%c\t%d\t%d\t%d\n", flag, formation.rate, formation.pcm, formation.midi); } if (!oxfw->has_output) return; /* Show output. */ err = snd_oxfw_stream_get_current_formation(oxfw, AVC_GENERAL_PLUG_DIR_OUT, &curr); if (err < 0) return; snd_iprintf(buffer, "Output Stream from device:\n"); snd_iprintf(buffer, "\tRate\tPCM\tMIDI\n"); for (i = 0; i < SND_OXFW_STREAM_FORMAT_ENTRIES; i++) { format = oxfw->tx_stream_formats[i]; if (format == NULL) continue; err = snd_oxfw_stream_parse_format(format, &formation); if (err < 0) continue; if (memcmp(&formation, &curr, sizeof(curr)) == 0) flag = '*'; else flag = ' '; snd_iprintf(buffer, "%c\t%d\t%d\t%d\n", flag, formation.rate, formation.pcm, formation.midi); } } static void add_node(struct snd_oxfw *oxfw, struct snd_info_entry *root, const char *name, void (*op)(struct snd_info_entry *e, struct snd_info_buffer *b)) { struct snd_info_entry *entry; entry = snd_info_create_card_entry(oxfw->card, name, root); if (entry == NULL) return; snd_info_set_text_ops(entry, oxfw, op); if (snd_info_register(entry) < 0) snd_info_free_entry(entry); } void snd_oxfw_proc_init(struct snd_oxfw *oxfw) { struct snd_info_entry *root; /* * All nodes are automatically removed at snd_card_disconnect(), * by following to link list. */ root = snd_info_create_card_entry(oxfw->card, "firewire", oxfw->card->proc_root); if (root == NULL) return; root->mode = S_IFDIR | S_IRUGO | S_IXUGO; if (snd_info_register(root) < 0) { snd_info_free_entry(root); return; } add_node(oxfw, root, "formation", proc_read_formation); } 42ded3fede7ca3acafc9153f4f2d0f56a92c'>root/sound/soc/tegra/tegra_rt5677.c
>5
AgeCommit message (Expand)AuthorFilesLines
space:
mode:
authorRuslan Ruslichenko <rruslich@cisco.com>2017-01-17 16:13:52 +0200
committerThomas Gleixner <tglx@linutronix.de>2017-01-18 15:37:28 +0100
commit020eb3daaba2857b32c4cf4c82f503d6a00a67de (patch)
tree329a05b424d783db675a4c711bd7633575e8181b /include/crypto/if_alg.h
parent49def1853334396f948dcb4cedb9347abb318df5 (diff)
x86/ioapic: Restore IO-APIC irq_chip retrigger callback
commit d32932d02e18 removed the irq_retrigger callback from the IO-APIC chip and did not add it to the new IO-APIC-IR irq chip. Unfortunately the software resend fallback is not enabled on X86, so edge interrupts which are received during the lazy disabled state of the interrupt line are not retriggered and therefor lost. Restore the callbacks. [ tglx: Massaged changelog ] Fixes: d32932d02e18 ("x86/irq: Convert IOAPIC to use hierarchical irqdomain interfaces") Signed-off-by: Ruslan Ruslichenko <rruslich@cisco.com> Cc: xe-linux-external@cisco.com Cc: stable@vger.kernel.org Link: http://lkml.kernel.org/r/1484662432-13580-1-git-send-email-rruslich@cisco.com Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/crypto/if_alg.h')