bitfield.hh
来自「M5,一个功能强大的多处理器系统模拟器.很多针对处理器架构,性能的研究都使用它作」· HH 代码 · 共 165 行
HH
165 行
/* * Copyright (c) 2003, 2004, 2005 * The Regents of The University of Michigan * All Rights Reserved * * This code is part of the M5 simulator. * * Permission is granted to use, copy, create derivative works and * redistribute this software and such derivative works for any * purpose, so long as the copyright notice above, this grant of * permission, and the disclaimer below appear in all copies made; and * so long as the name of The University of Michigan is not used in * any advertising or publicity pertaining to the use or distribution * of this software without specific, written prior authorization. * * THIS SOFTWARE IS PROVIDED AS IS, WITHOUT REPRESENTATION FROM THE * UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY PURPOSE, AND * WITHOUT WARRANTY BY THE UNIVERSITY OF MICHIGAN OF ANY KIND, EITHER * EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE. THE REGENTS OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE * LIABLE FOR ANY DAMAGES, INCLUDING DIRECT, SPECIAL, INDIRECT, * INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WITH RESPECT TO ANY CLAIM * ARISING OUT OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN * IF IT HAS BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF SUCH * DAMAGES. * * Authors: Steven K. Reinhardt * Nathan L. Binkert */#ifndef __BASE_BITFIELD_HH__#define __BASE_BITFIELD_HH__#include <inttypes.h>/** * Generate a 64-bit mask of 'nbits' 1s, right justified. */inline uint64_tmask(int nbits){ return (nbits == 64) ? (uint64_t)-1LL : (1ULL << nbits) - 1;}/** * Extract the bitfield from position 'first' to 'last' (inclusive) * from 'val' and right justify it. MSB is numbered 63, LSB is 0. */template <class T>inlineTbits(T val, int first, int last){ int nbits = first - last + 1; return (val >> last) & mask(nbits);}/** * Extract the bit from this position from 'val' and right justify it. */template <class T>inlineTbits(T val, int bit){ return bits(val, bit, bit);}/** * Mask off the given bits in place like bits() but without shifting. * msb = 63, lsb = 0 */template <class T>inlineTmbits(T val, int first, int last){ return val & (mask(first+1) & ~mask(last));}inline uint64_tmask(int first, int last){ return mbits((uint64_t)-1LL, first, last);}/** * Sign-extend an N-bit value to 64 bits. */template <int N>inlineint64_tsext(uint64_t val){ int sign_bit = bits(val, N-1, N-1); return sign_bit ? (val | ~mask(N)) : val;}/** * Return val with bits first to last set to bit_val */template <class T, class B>inlineTinsertBits(T val, int first, int last, B bit_val){ T t_bit_val = bit_val; T bmask = mask(first - last + 1) << last; return ((t_bit_val << last) & bmask) | (val & ~bmask);}/** * Overloaded for access to only one bit in value */template <class T, class B>inlineTinsertBits(T val, int bit, B bit_val){ return insertBits(val, bit, bit, bit_val);}/** * A convenience function to replace bits first to last of val with bit_val * in place. */template <class T, class B>inlinevoidreplaceBits(T& val, int first, int last, B bit_val){ val = insertBits(val, first, last, bit_val);}/** Overloaded function to allow to access only 1 bit*/template <class T, class B>inlinevoidreplaceBits(T& val, int bit, B bit_val){ val = insertBits(val, bit, bit, bit_val);}/** * Returns the bit position of the MSB that is set in the input */inlineintfindMsbSet(uint64_t val) { int msb = 0; if (!val) return 0; if (bits(val, 63,32)) { msb += 32; val >>= 32; } if (bits(val, 31,16)) { msb += 16; val >>= 16; } if (bits(val, 15,8)) { msb += 8; val >>= 8; } if (bits(val, 7,4)) { msb += 4; val >>= 4; } if (bits(val, 3,2)) { msb += 2; val >>= 2; } if (bits(val, 1,1)) { msb += 1; } return msb;}#endif // __BASE_BITFIELD_HH__
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?