亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? atomic.h

?? 嵌入式系統設計與實例開發源碼
?? H
字號:
/* * Atomic operations that C can't guarantee us.  Useful for * resource counting etc.. * * But use these as seldom as possible since they are much more slower * than regular operations. * * This file is subject to the terms and conditions of the GNU General Public * License.  See the file "COPYING" in the main directory of this archive * for more details. * * Copyright (C) 1996, 1997, 2000 by Ralf Baechle */#ifndef __ASM_ATOMIC_H#define __ASM_ATOMIC_H#include <linux/config.h>typedef struct { volatile int counter; } atomic_t;#ifdef __KERNEL__#define ATOMIC_INIT(i)    { (i) }/* * atomic_read - read atomic variable * @v: pointer of type atomic_t * * Atomically reads the value of @v.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */#define atomic_read(v)	((v)->counter)/* * atomic_set - set atomic variable * @v: pointer of type atomic_t * @i: required value * * Atomically sets the value of @v to @i.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */#define atomic_set(v,i)	((v)->counter = (i))#ifndef CONFIG_CPU_HAS_LLSC#include <asm/system.h>/* * The MIPS I implementation is only atomic with respect to * interrupts.  R3000 based multiprocessor machines are rare anyway ... * * atomic_add - add integer to atomic variable * @i: integer value to add * @v: pointer of type atomic_t * * Atomically adds @i to @v.  Note that the guaranteed useful range * of an atomic_t is only 24 bits. */extern __inline__ void atomic_add(int i, atomic_t * v){	int	flags;	save_flags(flags);	cli();	v->counter += i;	restore_flags(flags);}/* * atomic_sub - subtract the atomic variable * @i: integer value to subtract * @v: pointer of type atomic_t * * Atomically subtracts @i from @v.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */extern __inline__ void atomic_sub(int i, atomic_t * v){	int	flags;	save_flags(flags);	cli();	v->counter -= i;	restore_flags(flags);}extern __inline__ int atomic_add_return(int i, atomic_t * v){	int	temp, flags;	save_flags(flags);	cli();	temp = v->counter;	temp += i;	v->counter = temp;	restore_flags(flags);	return temp;}extern __inline__ int atomic_sub_return(int i, atomic_t * v){	int	temp, flags;	save_flags(flags);	cli();	temp = v->counter;	temp -= i;	v->counter = temp;	restore_flags(flags);	return temp;}#else/* * ... while for MIPS II and better we can use ll/sc instruction.  This * implementation is SMP safe ... *//* * atomic_add - add integer to atomic variable * @i: integer value to add * @v: pointer of type atomic_t * * Atomically adds @i to @v.  Note that the guaranteed useful range * of an atomic_t is only 24 bits. */extern __inline__ void atomic_add(int i, atomic_t * v){	unsigned long temp;	__asm__ __volatile__(		"1:   ll      %0, %1      # atomic_add\n"		"     addu    %0, %2                  \n"		"     sc      %0, %1                  \n"		"     beqz    %0, 1b                  \n"		: "=&r" (temp), "=m" (v->counter)		: "Ir" (i), "m" (v->counter));}/* * atomic_sub - subtract the atomic variable * @i: integer value to subtract * @v: pointer of type atomic_t * * Atomically subtracts @i from @v.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */extern __inline__ void atomic_sub(int i, atomic_t * v){	unsigned long temp;	__asm__ __volatile__(		"1:   ll      %0, %1      # atomic_sub\n"		"     subu    %0, %2                  \n"		"     sc      %0, %1                  \n"		"     beqz    %0, 1b                  \n"		: "=&r" (temp), "=m" (v->counter)		: "Ir" (i), "m" (v->counter));}/* * Same as above, but return the result value */extern __inline__ int atomic_add_return(int i, atomic_t * v){	unsigned long temp, result;	__asm__ __volatile__(		".set push               # atomic_add_return\n"		".set noreorder                             \n"		"1:   ll      %1, %2                        \n"		"     addu    %0, %1, %3                    \n"		"     sc      %0, %2                        \n"		"     beqz    %0, 1b                        \n"		"     addu    %0, %1, %3                    \n"		".set pop                                   \n"		: "=&r" (result), "=&r" (temp), "=m" (v->counter)		: "Ir" (i), "m" (v->counter)		: "memory");	return result;}extern __inline__ int atomic_sub_return(int i, atomic_t * v){	unsigned long temp, result;	__asm__ __volatile__(		".set push                                   \n"		".set noreorder           # atomic_sub_return\n"		"1:   ll    %1, %2                           \n"		"     subu  %0, %1, %3                       \n"		"     sc    %0, %2                           \n"		"     beqz  %0, 1b                           \n"		"     subu  %0, %1, %3                       \n"		".set pop                                    \n"		: "=&r" (result), "=&r" (temp), "=m" (v->counter)		: "Ir" (i), "m" (v->counter)		: "memory");	return result;}#endif#define atomic_dec_return(v) atomic_sub_return(1,(v))#define atomic_inc_return(v) atomic_add_return(1,(v))/* * atomic_sub_and_test - subtract value from variable and test result * @i: integer value to subtract * @v: pointer of type atomic_t * * Atomically subtracts @i from @v and returns * true if the result is zero, or false for all * other cases.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */#define atomic_sub_and_test(i,v) (atomic_sub_return((i), (v)) == 0)/* * atomic_inc_and_test - increment and test * @v: pointer of type atomic_t * * Atomically increments @v by 1 * and returns true if the result is zero, or false for all * other cases.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */#define atomic_inc_and_test(v) (atomic_inc_return(1, (v)) == 0)/* * atomic_dec_and_test - decrement by 1 and test * @v: pointer of type atomic_t * * Atomically decrements @v by 1 and * returns true if the result is 0, or false for all other * cases.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */#define atomic_dec_and_test(v) (atomic_sub_return(1, (v)) == 0)/* * atomic_inc - increment atomic variable * @v: pointer of type atomic_t * * Atomically increments @v by 1.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */#define atomic_inc(v) atomic_add(1,(v))/* * atomic_dec - decrement and test * @v: pointer of type atomic_t * * Atomically decrements @v by 1.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. */#define atomic_dec(v) atomic_sub(1,(v))/* * atomic_add_negative - add and test if negative * @v: pointer of type atomic_t * @i: integer value to add * * Atomically adds @i to @v and returns true * if the result is negative, or false when * result is greater than or equal to zero.  Note that the guaranteed * useful range of an atomic_t is only 24 bits. * * Currently not implemented for MIPS. *//* Atomic operations are already serializing */#define smp_mb__before_atomic_dec()	barrier()#define smp_mb__after_atomic_dec()	barrier()#define smp_mb__before_atomic_inc()	barrier()#define smp_mb__after_atomic_inc()	barrier()#endif /* defined(__KERNEL__) */#endif /* __ASM_ATOMIC_H */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩国产欧美在线观看| 91精品久久久久久蜜臀| 久久精品在线观看| 国产91精品在线观看| 国产精品久久综合| 日本福利一区二区| 日韩精品电影在线| 7777精品久久久大香线蕉 | 亚洲天堂久久久久久久| 色综合久久久久综合体| 亚洲国产日产av| 日韩免费观看高清完整版在线观看| 九色|91porny| 国产精品国模大尺度视频| 一本大道久久精品懂色aⅴ| 日欧美一区二区| ww久久中文字幕| 欧美精品v日韩精品v韩国精品v| 人妖欧美一区二区| 国产欧美一区二区精品秋霞影院| 成人av动漫网站| 日韩精彩视频在线观看| 日本一区二区三区dvd视频在线| 91丨porny丨国产| 男人的天堂亚洲一区| 中文字幕国产一区| 777午夜精品视频在线播放| 丁香网亚洲国际| 亚洲国产成人高清精品| 久久精品一区二区三区不卡牛牛 | 中文字幕精品三区| 欧美色老头old∨ideo| 国产成人免费视频网站| 五月天一区二区| 国产精品久久影院| 精品国产123| 91老师片黄在线观看| 麻豆国产精品视频| 一区二区三区日韩欧美精品| 久久久国产午夜精品| 精品电影一区二区| 国产真实乱子伦精品视频| 在线一区二区视频| 久久99久久99精品免视看婷婷| 国产精品电影院| 色噜噜狠狠成人网p站| 国产一区二区免费看| 国产亚洲自拍一区| 粉嫩一区二区三区在线看| 久久综合九色综合97婷婷| 国产一区二区日韩精品| 中文字幕亚洲在| 欧美人xxxx| 国产精品一区二区免费不卡| 国产精品美女久久久久久| 欧美性猛交xxxxxx富婆| 欧美a一区二区| 国产精品视频在线看| 欧美午夜电影网| 精品一区二区三区在线观看| 欧美激情综合在线| 欧美日韩免费一区二区三区视频| 天堂影院一区二区| 中文字幕av一区二区三区高 | 日本一区中文字幕| 日韩精品一区二区三区视频| 成人av网址在线| 日韩国产欧美在线观看| 中文子幕无线码一区tr| 91精品一区二区三区在线观看| 国产精品18久久久久久vr| 亚洲一区二区精品3399| 久久尤物电影视频在线观看| 在线亚洲+欧美+日本专区| 国产自产高清不卡| 亚洲在线免费播放| 国产亚洲综合色| 制服丝袜激情欧洲亚洲| 91丨九色丨国产丨porny| 捆绑调教一区二区三区| 亚洲久草在线视频| 久久久99精品免费观看不卡| 欧美三级资源在线| a4yy欧美一区二区三区| 久久se精品一区二区| 亚洲一区二区三区小说| 国产精品色哟哟| 精品91自产拍在线观看一区| 欧美精品 日韩| 一本到高清视频免费精品| 国产成人在线观看| 蜜桃av一区二区三区电影| 亚洲欧美另类小说视频| 国产三级一区二区| 欧美美女一区二区| 色爱区综合激月婷婷| 国产成人综合在线播放| 精品一区二区三区在线观看国产| 亚洲h动漫在线| 一区二区三区四区国产精品| 国产精品午夜久久| 欧美—级在线免费片| 欧美成人免费网站| 久久综合一区二区| 91精品国产综合久久精品| 欧美日韩一区不卡| 欧美色精品天天在线观看视频| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 日韩一区二区三区免费看 | 乱一区二区av| 日日摸夜夜添夜夜添亚洲女人| 亚洲午夜三级在线| 玉米视频成人免费看| 成人欧美一区二区三区白人 | 亚洲国产精品成人久久综合一区| 国产亚洲精品免费| 久久久综合精品| 国产日韩欧美精品在线| 欧美经典一区二区| 综合欧美一区二区三区| 中文字幕亚洲欧美在线不卡| 国产精品久久久久婷婷二区次| 亚洲欧美在线高清| 亚洲色图都市小说| 亚洲国产成人tv| 男女性色大片免费观看一区二区| 日韩成人伦理电影在线观看| 日精品一区二区三区| 麻豆成人综合网| 国产成人免费在线视频| www.日韩精品| 欧美日韩一区不卡| 欧美刺激午夜性久久久久久久| 精品国产一区二区在线观看| 国产精品丝袜91| 亚瑟在线精品视频| 另类小说一区二区三区| 成人激情黄色小说| 欧美网站一区二区| 久久这里只有精品视频网| 亚洲色欲色欲www| 日韩国产在线一| 国产精品自在欧美一区| 一本高清dvd不卡在线观看| 欧美一区二区三区四区久久| 久久综合色一综合色88| 亚洲欧美日韩一区二区 | 91在线观看美女| 69堂成人精品免费视频| 国产欧美一区二区三区网站| 亚洲无人区一区| 国产精品一区二区三区乱码| 欧美亚洲动漫精品| 久久久综合九色合综国产精品| 一区二区三区四区蜜桃| 国产一区二区视频在线播放| 色婷婷久久久久swag精品| 日韩精品专区在线影院重磅| 一色桃子久久精品亚洲| 麻豆精品一二三| 91浏览器在线视频| 26uuu久久天堂性欧美| 亚洲综合男人的天堂| 国产在线精品国自产拍免费| 欧美日韩国产一区| 成人免费在线播放视频| 韩国欧美国产一区| 欧美日精品一区视频| 中文字幕一区日韩精品欧美| 久久99国产精品麻豆| 欧美日韩激情一区二区三区| 久久精品亚洲麻豆av一区二区| 午夜精品福利一区二区三区av | 香蕉久久夜色精品国产使用方法| 国产精一品亚洲二区在线视频| 欧美精品视频www在线观看 | **欧美大码日韩| 国产传媒久久文化传媒| 日韩久久免费av| 免费黄网站欧美| 欧美日韩高清一区二区不卡| 一区二区三区免费网站| av一区二区三区在线| 久久久久久久久久久黄色| 日本色综合中文字幕| 欧美日韩大陆一区二区| 亚洲一区二区三区国产| 色美美综合视频| 亚洲欧洲色图综合| 99久久99久久免费精品蜜臀| 国产欧美va欧美不卡在线| 国产成人精品一区二区三区网站观看| 欧美一区二区大片| 日韩精品久久久久久| 91精品国产综合久久久久久久| 亚洲成人三级小说| 欧美丰满一区二区免费视频| 日韩精品一二三| 这里只有精品视频在线观看| 全国精品久久少妇|