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

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

?? shmpool.c

?? linux下的fusion程序,可以和directfb配合使用
?? C
字號:
/* *	Fusion Kernel Module * *	(c) Copyright 2002-2003  Convergence GmbH * *      Written by Denis Oliver Kropp <dok@directfb.org> * * *	This program is free software; you can redistribute it and/or *	modify it under the terms of the GNU General Public License *	as published by the Free Software Foundation; either version *	2 of the License, or (at your option) any later version. */#ifdef HAVE_LINUX_CONFIG_H#include <linux/config.h>#endif#include <linux/types.h>#include <linux/kernel.h>#include <linux/slab.h>#include <linux/smp_lock.h>#include <linux/sched.h>#include <linux/fusion.h>#include "fusiondev.h"#include "fusionee.h"#include "list.h"#include "shmpool.h"typedef struct {     FusionLink         link;     unsigned long      next_base;} AddrEntry;typedef struct {     FusionLink         link;     FusionID           fusion_id;     int                count;     /* number of attach calls */} SHMPoolNode;typedef struct {     FusionEntry        entry;     int                max_size;     void              *addr_base;     int                size;     AddrEntry         *addr_entry;     FusionLink        *nodes;     int                dispatch_count;} FusionSHMPool;/******************************************************************************/static SHMPoolNode *get_node      ( FusionSHMPool *shmpool,                                    FusionID       fusion_id );static void         remove_node   ( FusionSHMPool *shmpool,                                    FusionID       fusion_id );static int          fork_node     ( FusionSHMPool *shmpool,                                    FusionID       fusion_id,                                    FusionID       from_id );static void         free_all_nodes( FusionSHMPool *shmpool );/******************************************************************************/static DECLARE_MUTEX (addr_lock);static FusionLink    *addr_entries;static unsigned long  addr_base = FUSION_SHM_BASE;/******************************************************************************/static AddrEntry *add_addr_entry( unsigned long next_base ){     AddrEntry *entry = kmalloc( sizeof(AddrEntry), GFP_KERNEL );     entry->next_base = next_base;     fusion_list_prepend( &addr_entries, &entry->link );     return entry;}/******************************************************************************/static intfusion_shmpool_construct( FusionEntry *entry,                          void        *ctx,                          void        *create_ctx ){     FusionSHMPool    *shmpool = (FusionSHMPool*) entry;     FusionSHMPoolNew *poolnew = create_ctx;     down( &addr_lock );     if (addr_base + poolnew->max_size >= FUSION_SHM_BASE + FUSION_SHM_SIZE) {          up( &addr_lock );          printk( KERN_WARNING "%s: virtual address space exhausted! (FIXME)\n", __FUNCTION__ );          return -ENOSPC;     }     shmpool->max_size  = poolnew->max_size;     shmpool->addr_base = poolnew->addr_base = (void*) addr_base;     addr_base += PAGE_ALIGN(poolnew->max_size) + PAGE_SIZE; /* fence page */     shmpool->addr_entry = add_addr_entry( addr_base );     up( &addr_lock );     return 0;}static voidfusion_shmpool_destruct( FusionEntry *entry,                         void        *ctx ){     AddrEntry     *addr_entry;     FusionSHMPool *shmpool = (FusionSHMPool*) entry;     free_all_nodes( shmpool );     down( &addr_lock );     fusion_list_remove( &addr_entries, &shmpool->addr_entry->link );     /*      * free trailing address space      */     addr_base = FUSION_SHM_BASE;     fusion_list_foreach (addr_entry, addr_entries) {          if (addr_entry->next_base > addr_base)               addr_base = addr_entry->next_base;     }     up( &addr_lock );}static intfusion_shmpool_print( FusionEntry *entry,                      void        *ctx,                      char        *buf ){     int            num     = 0;     FusionSHMPool *shmpool = (FusionSHMPool*) entry;     FusionLink    *node    = shmpool->nodes;     fusion_list_foreach (node, shmpool->nodes) {          num++;     }     return sprintf( buf, "0x%p [0x%x] - 0x%x, %dx dispatch, %d nodes\n",                     shmpool->addr_base, shmpool->max_size, shmpool->size,                     shmpool->dispatch_count, num );}FUSION_ENTRY_CLASS( FusionSHMPool, shmpool, fusion_shmpool_construct,                    fusion_shmpool_destruct, fusion_shmpool_print )/******************************************************************************/intfusion_shmpool_init (FusionDev *dev){     fusion_entries_init( &dev->shmpool, &shmpool_class, dev );     create_proc_read_entry( "shmpools", 0, dev->proc_dir,                             fusion_entries_read_proc, &dev->shmpool );     return 0;}voidfusion_shmpool_deinit (FusionDev *dev){     remove_proc_entry ("shmpools", dev->proc_dir);     fusion_entries_deinit( &dev->shmpool );}/******************************************************************************/intfusion_shmpool_new (FusionDev        *dev,                    FusionSHMPoolNew *pool){     if (pool->max_size <= 0)          return -EINVAL;     return fusion_entry_create( &dev->shmpool, &pool->pool_id, pool );}intfusion_shmpool_attach (FusionDev           *dev,                       FusionSHMPoolAttach *attach,                       FusionID             fusion_id){     int            ret;     SHMPoolNode   *node;     FusionSHMPool *shmpool;     ret = fusion_shmpool_lock( &dev->shmpool, attach->pool_id, false, &shmpool );     if (ret)          return ret;     dev->stat.shmpool_attach++;     node = get_node (shmpool, fusion_id);     if (!node) {          node = kmalloc (sizeof(SHMPoolNode), GFP_KERNEL);          if (!node) {               fusion_shmpool_unlock( shmpool );               return -ENOMEM;          }          node->fusion_id = fusion_id;          node->count     = 1;          fusion_list_prepend (&shmpool->nodes, &node->link);     }     else          node->count++;     attach->addr_base = shmpool->addr_base;     attach->size      = shmpool->size;     fusion_shmpool_unlock( shmpool );     return 0;}intfusion_shmpool_detach (FusionDev *dev, int id, FusionID fusion_id){     int            ret;     SHMPoolNode   *node;     FusionSHMPool *shmpool;     ret = fusion_shmpool_lock( &dev->shmpool, id, false, &shmpool );     if (ret)          return ret;     dev->stat.shmpool_detach++;     node = get_node (shmpool, fusion_id);     if (!node) {          fusion_shmpool_unlock( shmpool );          return -EIO;     }     if (! --node->count) {          fusion_list_remove (&shmpool->nodes, &node->link);          kfree (node);     }     fusion_shmpool_unlock( shmpool );     return 0;}intfusion_shmpool_dispatch( FusionDev             *dev,                         FusionSHMPoolDispatch *dispatch,                         Fusionee              *fusionee ){     int                   ret;     FusionLink           *l;     FusionSHMPool        *shmpool;     FusionSHMPoolMessage  message;     FusionID              fusion_id = fusionee_id( fusionee );     if (dispatch->size <= 0)          return -EINVAL;     ret = fusion_shmpool_lock( &dev->shmpool, dispatch->pool_id, false, &shmpool );     if (ret)          return ret;     message.type = FSMT_REMAP;     message.size = dispatch->size;     shmpool->dispatch_count++;     shmpool->size = dispatch->size;     fusion_list_foreach (l, shmpool->nodes) {          SHMPoolNode *node = (SHMPoolNode *) l;          if (node->fusion_id == fusion_id)               continue;          fusionee_send_message (dev, fusionee, node->fusion_id, FMT_SHMPOOL,                                 shmpool->entry.id, 0, sizeof(message), &message,                                 NULL, NULL, 0);     }     fusion_shmpool_unlock( shmpool );     return 0;}intfusion_shmpool_destroy (FusionDev *dev, int id){     return fusion_entry_destroy( &dev->shmpool, id );}voidfusion_shmpool_detach_all (FusionDev *dev, FusionID fusion_id){     FusionLink *l;     down (&dev->shmpool.lock);     fusion_list_foreach (l, dev->shmpool.list) {          FusionSHMPool *shmpool = (FusionSHMPool *) l;          remove_node (shmpool, fusion_id);     }     up (&dev->shmpool.lock);}intfusion_shmpool_fork_all( FusionDev *dev,                         FusionID   fusion_id,                         FusionID   from_id ){     FusionLink *l;     int         ret = 0;     down (&dev->shmpool.lock);     fusion_list_foreach (l, dev->shmpool.list) {          FusionSHMPool *shmpool = (FusionSHMPool *) l;          ret = fork_node( shmpool, fusion_id, from_id );          if (ret)               break;     }     up (&dev->shmpool.lock);     return ret;}/******************************************************************************/static SHMPoolNode *get_node (FusionSHMPool *shmpool,          FusionID       fusion_id){     SHMPoolNode *node;     fusion_list_foreach (node, shmpool->nodes) {          if (node->fusion_id == fusion_id)               return node;     }     return NULL;}static voidremove_node (FusionSHMPool *shmpool, FusionID fusion_id){     SHMPoolNode *node;     down (&shmpool->entry.lock);     fusion_list_foreach (node, shmpool->nodes) {          if (node->fusion_id == fusion_id) {               fusion_list_remove (&shmpool->nodes, &node->link);               break;          }     }     up (&shmpool->entry.lock);}static intfork_node (FusionSHMPool *shmpool, FusionID fusion_id, FusionID from_id){     int          ret = 0;     SHMPoolNode *node;     down (&shmpool->entry.lock);     fusion_list_foreach (node, shmpool->nodes) {          if (node->fusion_id == from_id) {               SHMPoolNode *new_node;               new_node = kmalloc (sizeof(SHMPoolNode), GFP_KERNEL);               if (!new_node) {                    ret = -ENOMEM;                    break;               }               new_node->fusion_id = fusion_id;               new_node->count     = node->count;               fusion_list_prepend (&shmpool->nodes, &new_node->link);               break;          }     }     up (&shmpool->entry.lock);     return ret;}static voidfree_all_nodes (FusionSHMPool *shmpool){     FusionLink  *n;     SHMPoolNode *node;     fusion_list_foreach_safe (node, n, shmpool->nodes) {          kfree (node);     }     shmpool->nodes = NULL;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品久久精品| 欧美三片在线视频观看| 99国产精品一区| 51久久夜色精品国产麻豆| 久久久久久久久久久久久女国产乱 | 狠狠色2019综合网| 日本韩国一区二区三区视频| 久久久久综合网| 日韩精品每日更新| 91亚洲国产成人精品一区二区三| 日韩写真欧美这视频| 一区二区三区在线视频观看| 成人在线视频一区二区| 26uuu成人网一区二区三区| 亚洲国产成人va在线观看天堂| 国产成人精品www牛牛影视| 欧美一级高清大全免费观看| 一区二区成人在线| 99久久精品情趣| 中文字幕五月欧美| 成人精品高清在线| 久久日韩粉嫩一区二区三区| 日韩美女精品在线| 精品在线一区二区三区| 3atv在线一区二区三区| 一区二区三区中文字幕在线观看| 国产一区二区三区四区五区美女 | 99re这里只有精品首页| 欧美α欧美αv大片| 亚洲一区电影777| 成人动漫av在线| 精品国产乱码久久久久久闺蜜| 亚洲自拍偷拍av| 97久久超碰国产精品电影| wwww国产精品欧美| 麻豆专区一区二区三区四区五区| 91丨国产丨九色丨pron| 91精品国产91久久久久久最新毛片| 久久久久久久久久久黄色| 青草av.久久免费一区| 99精品国产视频| 欧美国产禁国产网站cc| 亚洲国产日日夜夜| 国产精品一区二区三区网站| 精品999在线播放| 韩日精品视频一区| 欧美精品一区二区精品网| 日韩和欧美一区二区| 欧美日韩国产首页在线观看| 亚洲福利一区二区三区| 在线观看av不卡| 亚洲制服丝袜在线| 欧美视频在线一区二区三区 | 欧美日韩激情在线| 亚洲电影一级黄| 欧美揉bbbbb揉bbbbb| 亚洲福利一区二区| 欧美老年两性高潮| 亚洲福利一二三区| 2024国产精品视频| 国产黄人亚洲片| 国产精品嫩草影院av蜜臀| 成人av在线影院| 亚洲女爱视频在线| 欧美日韩精品一区二区三区| 日韩电影网1区2区| 欧美日韩亚洲国产综合| 人妖欧美一区二区| 久久精品欧美一区二区三区不卡| 国产一区高清在线| 亚洲少妇30p| 欧美在线看片a免费观看| 婷婷开心久久网| 久久青草欧美一区二区三区| 成人在线视频一区| 亚洲精品第1页| 欧美色成人综合| 国产麻豆午夜三级精品| 亚洲久草在线视频| 欧美性感一类影片在线播放| 久久99久久精品欧美| 国产精品久久久久影院亚瑟| 欧美日韩一区成人| 国精产品一区一区三区mba视频 | 成人欧美一区二区三区黑人麻豆| 欧美高清hd18日本| 国产精品456| 日韩精品一级中文字幕精品视频免费观看 | 国产精品免费看片| 欧美日韩在线精品一区二区三区激情 | 日本女优在线视频一区二区| www激情久久| 日本韩国欧美三级| 精品一区二区影视| 亚洲精品欧美二区三区中文字幕| 91精品国产乱码| 91亚洲午夜精品久久久久久| 男女激情视频一区| 尤物av一区二区| 精品欧美乱码久久久久久1区2区| 国产福利精品一区二区| 欧美国产激情二区三区| 精品美女被调教视频大全网站| 91麻豆免费观看| 国产一区二区免费视频| 亚洲国产欧美另类丝袜| 国产精品入口麻豆原神| 精品国免费一区二区三区| 欧美在线播放高清精品| 国产精品中文字幕欧美| 人人精品人人爱| 一级日本不卡的影视| 亚洲国产成人一区二区三区| 日韩免费视频一区| 欧美精品成人一区二区三区四区| av一区二区久久| 日韩不卡一区二区| 久久日韩精品一区二区五区| 欧美色手机在线观看| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 国产一区二区在线观看视频| 日韩国产欧美在线播放| 自拍av一区二区三区| 中文文精品字幕一区二区| 精品久久人人做人人爱| 欧美男女性生活在线直播观看| 99久久精品国产毛片| 成人三级伦理片| 国产成人精品亚洲777人妖| 国产中文字幕精品| 国产一区二区三区av电影| 国产一区二区三区香蕉| 国产成人精品免费看| 国产精品99久久久| 国产精品77777| 国产精品一区二区不卡| 美女视频免费一区| 亚洲一区视频在线| 亚洲午夜免费电影| 亚洲一线二线三线久久久| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 欧美在线不卡视频| 在线观看日韩av先锋影音电影院| 91久久久免费一区二区| 色又黄又爽网站www久久| 91成人在线免费观看| 欧美色视频在线| 欧美一区三区四区| 精品国产欧美一区二区| 欧美国产一区二区在线观看 | 毛片av一区二区| 国产专区欧美精品| 不卡的av在线| 欧美日韩精品高清| 久久综合999| 亚洲天堂久久久久久久| 亚洲一区视频在线观看视频| 日本强好片久久久久久aaa| 精品一二三四区| 成人涩涩免费视频| 欧美三级蜜桃2在线观看| 91 com成人网| 国产日韩精品一区二区三区在线| 中文字幕中文字幕一区| 亚洲v中文字幕| 精品在线视频一区| 成人午夜免费电影| 欧美日韩在线播放三区| www国产成人免费观看视频 深夜成人网| 久久青草欧美一区二区三区| 亚洲男帅同性gay1069| 日本一不卡视频| eeuss鲁片一区二区三区在线观看| 在线一区二区三区四区五区| 日韩一区二区免费高清| 亚洲欧美日韩国产另类专区| 美女在线观看视频一区二区| 99国产欧美久久久精品| 欧美videossexotv100| ㊣最新国产の精品bt伙计久久| 亚洲成a人v欧美综合天堂| 国产精品一区二区三区四区| 色菇凉天天综合网| 久久天堂av综合合色蜜桃网 | 日韩一区国产二区欧美三区| 国产精品美女久久久久aⅴ| 日韩黄色免费网站| 91在线云播放| 7799精品视频| 亚洲欧美aⅴ...| 高清免费成人av| 日韩免费观看高清完整版| 亚洲精品高清在线观看| 国产999精品久久久久久| 欧美一区日本一区韩国一区| 亚洲码国产岛国毛片在线| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美巨大另类极品videosbest | 香蕉加勒比综合久久| 99在线精品视频|