42 lines
		
	
	
		
			752 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			752 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __ASM_CPU_SH3_DAC_H
 | |
| #define __ASM_CPU_SH3_DAC_H
 | |
| 
 | |
| /*
 | |
|  * Copyright (C) 2003  Andriy Skulysh
 | |
|  */
 | |
| 
 | |
| 
 | |
| #define DADR0	0xa40000a0
 | |
| #define DADR1	0xa40000a2
 | |
| #define DACR	0xa40000a4
 | |
| #define DACR_DAOE1	0x80
 | |
| #define DACR_DAOE0	0x40
 | |
| #define DACR_DAE	0x20
 | |
| 
 | |
| 
 | |
| static __inline__ void sh_dac_enable(int channel)
 | |
| {
 | |
| 	unsigned char v;
 | |
| 	v = ctrl_inb(DACR);
 | |
| 	if(channel) v |= DACR_DAOE1;
 | |
| 	else v |= DACR_DAOE0;
 | |
| 	ctrl_outb(v,DACR);
 | |
| }
 | |
| 
 | |
| static __inline__ void sh_dac_disable(int channel)
 | |
| {
 | |
| 	unsigned char v;
 | |
| 	v = ctrl_inb(DACR);
 | |
| 	if(channel) v &= ~DACR_DAOE1;
 | |
| 	else v &= ~DACR_DAOE0;
 | |
| 	ctrl_outb(v,DACR);
 | |
| }
 | |
| 
 | |
| static __inline__ void sh_dac_output(u8 value, int channel)
 | |
| {
 | |
| 	if(channel) ctrl_outb(value,DADR1);
 | |
| 	else ctrl_outb(value,DADR0);
 | |
| }
 | |
| 
 | |
| #endif /* __ASM_CPU_SH3_DAC_H */
 |