2006-11-11 17:24:53 +11:00
/*
* ( c ) Copyright 2006 Benjamin Herrenschmidt , IBM Corp .
* < benh @ kernel . crashing . org >
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See
* the GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program ; if not , write to the Free Software
* Foundation , Inc . , 59 Temple Place , Suite 330 , Boston , MA 02111 - 1307 USA
*/
# ifndef _ASM_POWERPC_DCR_MMIO_H
# define _ASM_POWERPC_DCR_MMIO_H
# ifdef __KERNEL__
# include <asm/io.h>
2007-09-17 16:05:00 +10:00
typedef struct {
void __iomem * token ;
unsigned int stride ;
unsigned int base ;
} dcr_host_t ;
2006-11-11 17:24:53 +11:00
# define DCR_MAP_OK(host) ((host).token != NULL)
extern dcr_host_t dcr_map ( struct device_node * dev , unsigned int dcr_n ,
unsigned int dcr_c ) ;
2007-10-15 19:34:37 +10:00
extern void dcr_unmap ( dcr_host_t host , unsigned int dcr_c ) ;
2006-11-11 17:24:53 +11:00
static inline u32 dcr_read ( dcr_host_t host , unsigned int dcr_n )
{
2007-10-15 19:34:36 +10:00
return in_be32 ( host . token + ( ( host . base + dcr_n ) * host . stride ) ) ;
2006-11-11 17:24:53 +11:00
}
static inline void dcr_write ( dcr_host_t host , unsigned int dcr_n , u32 value )
{
2007-10-15 19:34:36 +10:00
out_be32 ( host . token + ( ( host . base + dcr_n ) * host . stride ) , value ) ;
2006-11-11 17:24:53 +11:00
}
extern u64 of_translate_dcr_address ( struct device_node * dev ,
unsigned int dcr_n ,
unsigned int * stride ) ;
# endif /* __KERNEL__ */
# endif /* _ASM_POWERPC_DCR_MMIO_H */