#ifndef _GPXE_BITBASH_H #define _GPXE_BITBASH_H /** @file * * Bit-bashing interfaces * */ FILE_LICENCE ( GPL2_OR_LATER ); struct bit_basher; /** Bit-bashing operations */ struct bit_basher_operations { /** * 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; }; 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 /* _GPXE_BITBASH_H */