varint.h
D:/gitt/MicrochipFor32/bsp_Device/varint.h
浏览该文件的文档.00001 /*----------------------------------------------------------------------------------------------------
00002 #
00003 # Copyright (c) 2022 Yuankang Liang(XerolySkinner)
00004 #
00005 # 本软件按原样提供,无任何明示或暗示
00006 # 在任何情况下,作者都不承担任何损害赔偿责任
00007 #
00008 # 使用的许可声明:
00009 # 1. 不得歪曲本软件的来源,你不能声称你编写了原始软件.
00010 # 2. 免费授予以任何目的,前提是版权声明出现在所有副本中.
00011 # 并且版权声明和许可声明同时出现.
00012 # 3. 你有使用,复制,修改,分发,和销售本软件的许可.
00013 # 4. 如果你在产品中使用,产品文档中的声明是赞赏的但不是必须的.
00014 # 5. 本通知不得从任何来源删除或更改.
00015 #
00016 # Yuankang Liang(XerolySkinner)
00017 # E-mail:zabbcccbbaz@163.com
00018 # QQ:2715099320
00019 # Mobile Phone:13005636215
00020 #
00021 # All rights reserved.
00022 */
00023
00034 #pragma once
00035 #include "stdint.h"
00037 //----------------------------------------------------------------------------------------------------
00038 // 程序
00039 //
00040 typedef uint8_t u8;
00041 typedef uint16_t u16;
00042 typedef uint32_t u32;
00043 typedef uint64_t u64;
00044
00045 typedef int8_t i8;
00046 typedef int16_t i16;
00047 typedef int32_t i32;
00048 typedef int64_t i64;
00049
00050 typedef volatile u8 vu8;
00051 typedef volatile u16 vu16;
00052 typedef volatile u32 vu32;
00053 typedef volatile u64 vu64;
00054
00055 typedef volatile i8 vi8;
00056 typedef volatile i16 vi16;
00057 typedef volatile i32 vi32;
00058 typedef volatile i64 vi64;
00060 //----------------------------------------------------------------------------------------------------
00061 // 位宏
00062 #define P8(x) ((u8*)(&(x)))
00063 #define Pn8(x,y) (((u8*)(&(x)))[y])
00064 #define P16(x) ((u16*)(&(x)))
00065 #define Pn16(x,y) (((u16*)(&(x)))[y])
00066 #define P32(x) ((u32*)(&(x)))
00067 #define Pn32(x,y) (((u32*)(&(x)))[y])
00068
00069 #define DelLb(x) (x & (x - 1))
00070 #define qDelLb(x) (x=(x & (x - 1)))
00071
00072 #define toBool(x) (x!=0)
00073 #define uBit(x,y) (x&(1<<y))
00074 #define tBit(x,y) (toBool(uBit(x,y)))
00075
00076 #define sBit(x,y) (x|(1<<y))
00077 #define rBit(x,y) (x&(~(1<<y)))
00078 #define mBit(x,y,z) ((z)?sBit(x,y):rBit(x,y))
00079
00080 #define LpAdd(x,y) ((x+1)<y?x+1:0)
00081 #define LpDec(x,y) (x>0?x-1:y-1)
00082 #define qLpAdd(x,y) (x=(x+1)<y?x+1:0)
00083 #define qLpDec(x,y) (x=x>0?x-1:y-1)
00085