提交 62cef821 编写于 作者: D Denys Vlasenko 提交者: Takashi Iwai

[ALSA] sound/pci/rme9652/hdspm.c: stop inlining largish static functions

sound/pci/rme9652/hdspm.c has unusually large number of static inline
functions - 22.

I looked through them and some of them seem to be too big to warrant inlining.

This patch removes "inline" from these static functions (regardless of number
of callsites - gcc nowadays auto-inlines statics with one callsite).

Size difference on 32bit x86:
   text    data     bss     dec     hex filename
  20437    2160     516   23113    5a49 linux-2.6-ALLYES/sound/pci/rme9652/hdspm.o
  18036    2160     516   20712    50e8 linux-2.6.inline-ALLYES/sound/pci/rme9652/hdspm.o

[coding fix by Takashi Iwai <tiwai@suse.de>]
Signed-off-by: NDenys Vlasenko <vda.linux@googlemail.com>
Signed-off-by: NTakashi Iwai <tiwai@suse.de>
上级 32f4876e
...@@ -540,7 +540,8 @@ static void hdspm_set_sgbuf(struct hdspm * hdspm, struct snd_sg_buf *sgbuf, ...@@ -540,7 +540,8 @@ static void hdspm_set_sgbuf(struct hdspm * hdspm, struct snd_sg_buf *sgbuf,
static inline int HDSPM_bit2freq(int n) static inline int HDSPM_bit2freq(int n)
{ {
static int bit2freq_tab[] = { 0, 32000, 44100, 48000, 64000, 88200, static const int bit2freq_tab[] = {
0, 32000, 44100, 48000, 64000, 88200,
96000, 128000, 176400, 192000 }; 96000, 128000, 176400, 192000 };
if (n < 1 || n > 9) if (n < 1 || n > 9)
return 0; return 0;
...@@ -582,7 +583,7 @@ static inline int hdspm_read_pb_gain(struct hdspm * hdspm, unsigned int chan, ...@@ -582,7 +583,7 @@ static inline int hdspm_read_pb_gain(struct hdspm * hdspm, unsigned int chan,
return hdspm->mixer->ch[chan].pb[pb]; return hdspm->mixer->ch[chan].pb[pb];
} }
static inline int hdspm_write_in_gain(struct hdspm * hdspm, unsigned int chan, static int hdspm_write_in_gain(struct hdspm *hdspm, unsigned int chan,
unsigned int in, unsigned short data) unsigned int in, unsigned short data)
{ {
if (chan >= HDSPM_MIXER_CHANNELS || in >= HDSPM_MIXER_CHANNELS) if (chan >= HDSPM_MIXER_CHANNELS || in >= HDSPM_MIXER_CHANNELS)
...@@ -595,7 +596,7 @@ static inline int hdspm_write_in_gain(struct hdspm * hdspm, unsigned int chan, ...@@ -595,7 +596,7 @@ static inline int hdspm_write_in_gain(struct hdspm * hdspm, unsigned int chan,
return 0; return 0;
} }
static inline int hdspm_write_pb_gain(struct hdspm * hdspm, unsigned int chan, static int hdspm_write_pb_gain(struct hdspm *hdspm, unsigned int chan,
unsigned int pb, unsigned short data) unsigned int pb, unsigned short data)
{ {
if (chan >= HDSPM_MIXER_CHANNELS || pb >= HDSPM_MIXER_CHANNELS) if (chan >= HDSPM_MIXER_CHANNELS || pb >= HDSPM_MIXER_CHANNELS)
...@@ -621,7 +622,7 @@ static inline void snd_hdspm_enable_out(struct hdspm * hdspm, int i, int v) ...@@ -621,7 +622,7 @@ static inline void snd_hdspm_enable_out(struct hdspm * hdspm, int i, int v)
} }
/* check if same process is writing and reading */ /* check if same process is writing and reading */
static inline int snd_hdspm_use_is_exclusive(struct hdspm * hdspm) static int snd_hdspm_use_is_exclusive(struct hdspm *hdspm)
{ {
unsigned long flags; unsigned long flags;
int ret = 1; int ret = 1;
...@@ -636,7 +637,7 @@ static inline int snd_hdspm_use_is_exclusive(struct hdspm * hdspm) ...@@ -636,7 +637,7 @@ static inline int snd_hdspm_use_is_exclusive(struct hdspm * hdspm)
} }
/* check for external sample rate */ /* check for external sample rate */
static inline int hdspm_external_sample_rate(struct hdspm * hdspm) static int hdspm_external_sample_rate(struct hdspm *hdspm)
{ {
if (hdspm->is_aes32) { if (hdspm->is_aes32) {
unsigned int status2 = hdspm_read(hdspm, HDSPM_statusRegister2); unsigned int status2 = hdspm_read(hdspm, HDSPM_statusRegister2);
...@@ -787,7 +788,7 @@ static inline void hdspm_stop_audio(struct hdspm * s) ...@@ -787,7 +788,7 @@ static inline void hdspm_stop_audio(struct hdspm * s)
} }
/* should I silence all or only opened ones ? doit all for first even is 4MB*/ /* should I silence all or only opened ones ? doit all for first even is 4MB*/
static inline void hdspm_silence_playback(struct hdspm * hdspm) static void hdspm_silence_playback(struct hdspm *hdspm)
{ {
int i; int i;
int n = hdspm->period_bytes; int n = hdspm->period_bytes;
...@@ -1057,7 +1058,7 @@ static inline int snd_hdspm_midi_output_possible (struct hdspm *hdspm, int id) ...@@ -1057,7 +1058,7 @@ static inline int snd_hdspm_midi_output_possible (struct hdspm *hdspm, int id)
return 0; return 0;
} }
static inline void snd_hdspm_flush_midi_input (struct hdspm *hdspm, int id) static void snd_hdspm_flush_midi_input(struct hdspm *hdspm, int id)
{ {
while (snd_hdspm_midi_input_available (hdspm, id)) while (snd_hdspm_midi_input_available (hdspm, id))
snd_hdspm_midi_read_byte (hdspm, id); snd_hdspm_midi_read_byte (hdspm, id);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册