• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天下

            記錄修行的印記

            Linux內(nèi)核的同步機(jī)制(2)信號量(semaphore)

            Linux內(nèi)核的同步機(jī)制(2)信號量(semaphore)

              信號量在創(chuàng)建時需要設(shè)置一個初始值,表示同時可以有幾個任務(wù)可以訪問該信號量保護(hù)的共享資源,初始值為1就變成互斥鎖(Mutex),即同時只能有一個任務(wù)可以訪問信號量保護(hù)的共享資源。

              一個任務(wù)要想訪問共享資源,首先必須得到信號量,獲取信號量的操作將把信號量的值減1,若當(dāng)前信號量的值為負(fù)數(shù),表明無法獲得信號量,該任務(wù)必須掛起在該信號量的等待隊列等待該信號量可用;若當(dāng)前信號量的值為非負(fù)數(shù),表示可以獲得信號量,因而可以立刻訪問被該信號量保護(hù)的共享資源。

              當(dāng)任務(wù)訪問完被信號量保護(hù)的共享資源后,必須釋放信號量,釋放信號量通過把信號量的值加1實現(xiàn),如果信號量的值為非正數(shù),表明有任務(wù)等待當(dāng)前信號量,因此它也喚醒所有等待該信號量的任務(wù)。

            信號量的API有:
            DECLARE_MUTEX(name)
            該宏聲明一個信號量name并初始化它的值為1,即聲明一個互斥鎖。

            //在Linux2.6.26中沒找到該宏
            DECLARE_MUTEX_LOCKED(name)
            該宏聲明一個互斥鎖name,但把它的初始值設(shè)置為0,即鎖在創(chuàng)建時就處在已鎖狀態(tài)。因此對于這種鎖,一般是先釋放后獲得。

            void sema_init (struct semaphore *sem, int val);
            該函用于數(shù)初始化設(shè)置信號量的初值,它設(shè)置信號量sem的值為val。

            void init_MUTEX (struct semaphore *sem);
            該函數(shù)用于初始化一個互斥鎖,即它把信號量sem的值設(shè)置為1。

            void init_MUTEX_LOCKED (struct semaphore *sem);
            該函數(shù)也用于初始化一個互斥鎖,但它把信號量sem的值設(shè)置為0,即一開始就處在已鎖狀態(tài)。

            void down(struct semaphore * sem);
            該函數(shù)用于獲得信號量sem,它會導(dǎo)致睡眠,因此不能在中斷上下文(包括IRQ上下文和softirq上下文)使用該函數(shù)。該函數(shù)將把sem的值減1,如果信號量sem的值非負(fù),就直接返回,否則調(diào)用者將被掛起,直到別的任務(wù)釋放該信號量才能繼續(xù)運(yùn)行。

            int down_interruptible(struct semaphore * sem);
            該函數(shù)功能與down類似,不同之處為,down不會被信號(signal)打斷,但down_interruptible能被信號打斷,因此該函數(shù)有返回值來區(qū)分是正常返回還是被信號中斷,如果返回0,表示獲得信號量正常返回,如果被信號打斷,返回-EINTR。

            int down_trylock(struct semaphore * sem);
            該函數(shù)試著獲得信號量sem,如果能夠立刻獲得,它就獲得該信號量并返回0,否則,表示不能獲得信號量sem,返回值為非0值。因此,它不會導(dǎo)致調(diào)用者睡眠,可以在中斷上下文使用。

            void up(struct semaphore * sem);
            該函數(shù)釋放信號量sem,即把sem的值加1,如果sem的值為非正數(shù),表明有任務(wù)等待該信號量,因此喚醒這些等待者。 

            頭文件:
            #include <linux/semaphore.h>
            /*
             * Copyright (c) 2008 Intel Corporation
             * Author: Matthew Wilcox <willy@linux.intel.com>
             *
             * Distributed under the terms of the GNU GPL, version 2
             *
             * Please see kernel/semaphore.c for documentation of these functions
             
            */
            #ifndef __LINUX_SEMAPHORE_H
            #define __LINUX_SEMAPHORE_H

            #include <linux/list.h>
            #include <linux/spinlock.h>

            /* Please don't access any members of this structure directly */
            struct semaphore {
                spinlock_t        lock;
                unsigned int        count;
                struct list_head    wait_list;
            };

            #define __SEMAPHORE_INITIALIZER(name, n)                \
            {                                    \
                .lock        = __SPIN_LOCK_UNLOCKED((name).lock),        \
                .count        = n,                        \
                .wait_list    = LIST_HEAD_INIT((name).wait_list),        \
            }

            #define __DECLARE_SEMAPHORE_GENERIC(name, count) \
                struct semaphore name = __SEMAPHORE_INITIALIZER(name, count)

            #define DECLARE_MUTEX(name)    __DECLARE_SEMAPHORE_GENERIC(name, 1)

            static inline void sema_init(struct semaphore *sem, int val)
            {
                static struct lock_class_key __key;
                *sem = (struct semaphore) __SEMAPHORE_INITIALIZER(*sem, val);
                lockdep_init_map(&sem->lock.dep_map, "semaphore->lock", &__key, 0);
            }

            #define init_MUTEX(sem)        sema_init(sem, 1)
            #define init_MUTEX_LOCKED(sem)    sema_init(sem, 0)

            extern void down(struct semaphore *sem);
            extern int __must_check down_interruptible(struct semaphore *sem);
            extern int __must_check down_killable(struct semaphore *sem);
            extern int __must_check down_trylock(struct semaphore *sem);
            extern int __must_check down_timeout(struct semaphore *sem, long jiffies);
            extern void up(struct semaphore *sem);

            #endif /* __LINUX_SEMAPHORE_H */

            posted on 2013-04-12 18:22 天下 閱讀(2315) 評論(0)  編輯 收藏 引用 所屬分類: kernel & Driver

            <2012年7月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            国产精品久久99| 久久综合中文字幕| 久久妇女高潮几次MBA| 国产精品久久久久蜜芽| 色偷偷88888欧美精品久久久| 久久精品国产第一区二区三区 | 欧美午夜A∨大片久久 | 久久精品国产2020| 久久国产精品99精品国产987| 久久精品国产亚洲Aⅴ蜜臀色欲| 欧美午夜A∨大片久久| 日本久久久久久中文字幕| 99久久这里只精品国产免费| 欧美亚洲国产精品久久蜜芽| 久久久久久精品久久久久| 99久久精品久久久久久清纯| 国产精品99久久久精品无码| 精品人妻伦九区久久AAA片69| 新狼窝色AV性久久久久久| 三级韩国一区久久二区综合 | 精品国产91久久久久久久a| 精品久久人人做人人爽综合| 久久九九精品99国产精品| 久久精品国产男包| 国产福利电影一区二区三区,免费久久久久久久精 | 久久水蜜桃亚洲av无码精品麻豆| 伊人久久无码精品中文字幕| 精品久久久久中文字| 人人狠狠综合久久亚洲88| 久久国产精品无码一区二区三区| 噜噜噜色噜噜噜久久| 中文字幕久久波多野结衣av| 一本一道久久a久久精品综合| 人妻系列无码专区久久五月天| 久久精品这里热有精品| 久久精品草草草| 日韩一区二区久久久久久 | 亚洲精品国精品久久99热 | 2021久久精品国产99国产精品| 久久婷婷五月综合97色一本一本| 亚洲精品无码久久久久|