| #ifndef _IPXE_BITBASH_H |
| #define _IPXE_BITBASH_H |
| |
| /** @file |
| * |
| * Bit-bashing interfaces |
| * |
| */ |
| |
| FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL ); |
| |
| struct bit_basher; |
| |
| /** Bit-bashing operations */ |
| struct bit_basher_operations { |
| /** |
| * Open bit-bashing interface (optional) |
| * |
| * @v basher Bit-bashing interface |
| */ |
| void ( * open ) ( struct bit_basher *basher ); |
| /** |
| * Close bit-bashing interface (optional) |
| * |
| * @v basher Bit-bashing interface |
| */ |
| void ( * close ) ( struct bit_basher *basher ); |
| /** |
| * Set/clear output bit |
| * |
| * @v basher Bit-bashing interface |
| * @v bit_id Bit number |
| * @v data Value to write |
| * |
| * @c data will be 0 if a logic 0 should be written (i.e. the |
| * bit should be cleared), or -1UL if a logic 1 should be |
| * written (i.e. the bit should be set). This is done so that |
| * the method may simply binary-AND @c data with the |
| * appropriate bit mask. |
| */ |
| void ( * write ) ( struct bit_basher *basher, unsigned int bit_id, |
| unsigned long data ); |
| /** |
| * Read input bit |
| * |
| * @v basher Bit-bashing interface |
| * @v bit_id Bit number |
| * @ret zero Input is a logic 0 |
| * @ret non-zero Input is a logic 1 |
| */ |
| int ( * read ) ( struct bit_basher *basher, unsigned int bit_id ); |
| }; |
| |
| /** A bit-bashing interface */ |
| struct bit_basher { |
| /** Bit-bashing operations */ |
| struct bit_basher_operations *op; |
| }; |
| |
| /** |
| * Open bit-bashing interface |
| * |
| * @v basher Bit-bashing interface |
| */ |
| static inline void open_bit ( struct bit_basher *basher ) { |
| if ( basher->op->open ) |
| basher->op->open ( basher ); |
| } |
| |
| /** |
| * Close bit-bashing interface |
| * |
| * @v basher Bit-bashing interface |
| */ |
| static inline void close_bit ( struct bit_basher *basher ) { |
| if ( basher->op->close ) |
| basher->op->close ( basher ); |
| } |
| |
| extern void write_bit ( struct bit_basher *basher, unsigned int bit_id, |
| unsigned long data ); |
| extern int read_bit ( struct bit_basher *basher, unsigned int bit_id ); |
| |
| #endif /* _IPXE_BITBASH_H */ |