mirror of
				https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
				synced 2025-11-03 09:01:50 -05:00 
			
		
		
		
	Hardware source volume support.
git-svn-id: file:///home/lennart/svn/public/pulseaudio/trunk@584 fefdeb5f-60dc-0310-8127-8f9354f1896f
This commit is contained in:
		
							parent
							
								
									4e8faa6deb
								
							
						
					
					
						commit
						79e8009045
					
				
					 1 changed files with 38 additions and 0 deletions
				
			
		| 
						 | 
					@ -292,6 +292,40 @@ static int sink_set_hw_volume_cb(pa_sink *s) {
 | 
				
			||||||
    return 0;
 | 
					    return 0;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int source_get_hw_volume_cb(pa_source *s) {
 | 
				
			||||||
 | 
					    struct userdata *u = s->userdata;
 | 
				
			||||||
 | 
					    audio_info_t info;
 | 
				
			||||||
 | 
					    int err;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    err = ioctl(u->fd, AUDIO_GETINFO, &info);
 | 
				
			||||||
 | 
					    assert(err >= 0);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    pa_cvolume_set(&s->hw_volume, s->hw_volume.channels,
 | 
				
			||||||
 | 
					        info.record.gain * PA_VOLUME_NORM / AUDIO_MAX_GAIN);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int source_set_hw_volume_cb(pa_source *s) {
 | 
				
			||||||
 | 
					    struct userdata *u = s->userdata;
 | 
				
			||||||
 | 
					    audio_info_t info;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    AUDIO_INITINFO(&info);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    info.record.gain = pa_cvolume_avg(&s->hw_volume) * AUDIO_MAX_GAIN / PA_VOLUME_NORM;
 | 
				
			||||||
 | 
					    assert(info.record.gain <= AUDIO_MAX_GAIN);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (ioctl(u->fd, AUDIO_SETINFO, &info) < 0) {
 | 
				
			||||||
 | 
					        if (errno == EINVAL)
 | 
				
			||||||
 | 
					            pa_log(__FILE__": AUDIO_SETINFO: Unsupported volume.");
 | 
				
			||||||
 | 
					        else
 | 
				
			||||||
 | 
					            pa_log(__FILE__": AUDIO_SETINFO: %s", strerror(errno));
 | 
				
			||||||
 | 
					        return -1;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int pa_solaris_auto_format(int fd, int mode, pa_sample_spec *ss) {
 | 
					static int pa_solaris_auto_format(int fd, int mode, pa_sample_spec *ss) {
 | 
				
			||||||
    audio_info_t info;
 | 
					    audio_info_t info;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -436,6 +470,8 @@ int pa__init(pa_core *c, pa_module*m) {
 | 
				
			||||||
        assert(u->source);
 | 
					        assert(u->source);
 | 
				
			||||||
        u->source->userdata = u;
 | 
					        u->source->userdata = u;
 | 
				
			||||||
        u->source->get_latency = source_get_latency_cb;
 | 
					        u->source->get_latency = source_get_latency_cb;
 | 
				
			||||||
 | 
					        u->source->get_hw_volume = source_get_hw_volume_cb;
 | 
				
			||||||
 | 
					        u->source->set_hw_volume = source_set_hw_volume_cb;
 | 
				
			||||||
        pa_source_set_owner(u->source, m);
 | 
					        pa_source_set_owner(u->source, m);
 | 
				
			||||||
        u->source->description = pa_sprintf_malloc("Solaris PCM on '%s'", p);
 | 
					        u->source->description = pa_sprintf_malloc("Solaris PCM on '%s'", p);
 | 
				
			||||||
    } else
 | 
					    } else
 | 
				
			||||||
| 
						 | 
					@ -483,6 +519,8 @@ int pa__init(pa_core *c, pa_module*m) {
 | 
				
			||||||
    pa_modargs_free(ma);
 | 
					    pa_modargs_free(ma);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* Read mixer settings */
 | 
					    /* Read mixer settings */
 | 
				
			||||||
 | 
					    if (u->source)
 | 
				
			||||||
 | 
					        sink_get_hw_volume_cb(u->source);
 | 
				
			||||||
    if (u->sink)
 | 
					    if (u->sink)
 | 
				
			||||||
        sink_get_hw_volume_cb(u->sink);
 | 
					        sink_get_hw_volume_cb(u->sink);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue