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

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

?? rb.c

?? Aqualung is an advanced music player primarily targeted for the GNU/Linux operating system, but als
?? C
字號:
/*  Copyright (C) 2000 Paul Davis  Copyright (C) 2003 Rohan Drape      This program is free software; you can redistribute it and/or modify  it under the terms of the GNU Lesser General Public License as published by  the Free Software Foundation; either version 2.1 of the License, or  (at your option) any later version.      This program is distributed in the hope that it will be useful,  but WITHOUT ANY WARRANTY; without even the implied warranty of  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the  GNU Lesser General Public License for more details.      You should have received a copy of the GNU Lesser General Public License  along with this program; if not, write to the Free Software   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.      ISO/POSIX C version of Paul Davis's lock free ringbuffer C++ code.  This is safe for the case of one read thread and one write thread.*/#include <config.h>#include <stdlib.h>#include <string.h>#ifdef USE_MLOCK#include <sys/mman.h>#endif /* USE_MLOCK */#include "rb.h"/* Create a new ringbuffer to hold at least `sz' bytes of data. The   actual buffer size is rounded up to the next power of two.  */rb_t *rb_create (size_t sz){  int power_of_two;  rb_t *rb;  rb = calloc (1, sizeof (rb_t));  for (power_of_two = 1; 1 << power_of_two < sz; power_of_two++);  rb->size = 1 << power_of_two;  rb->size_mask = rb->size;  rb->size_mask -= 1;  rb->write_ptr = 0;  rb->read_ptr = 0;  rb->buf = calloc (1, rb->size);  rb->mlocked = 0;  return rb;}/* Free all data associated with the ringbuffer `rb'. */voidrb_free (rb_t * rb){#ifdef USE_MLOCK  if (rb->mlocked) {    munlock (rb->buf, rb->size);  }#endif /* USE_MLOCK */  free (rb->buf);}/* Lock the data block of `rb' using the system call 'mlock'.  */intrb_mlock (rb_t * rb){#ifdef USE_MLOCK  if (mlock (rb->buf, rb->size)) {    return -1;  }#endif /* USE_MLOCK */  rb->mlocked = 1;  return 0;}/* Reset the read and write pointers to zero. This is not thread   safe. */voidrb_reset (rb_t * rb){  rb->read_ptr = 0;  rb->write_ptr = 0;}/* Return the number of bytes available for reading.  This is the   number of bytes in front of the read pointer and behind the write   pointer.  */size_trb_read_space (const rb_t * rb){  size_t w, r;  w = rb->write_ptr;  r = rb->read_ptr;  if (w > r) {    return w - r;  } else {    return (w - r + rb->size) & rb->size_mask;  }}/* Return the number of bytes available for writing.  This is the   number of bytes in front of the write pointer and behind the read   pointer.  */size_trb_write_space (const rb_t * rb){  size_t w, r;  w = rb->write_ptr;  r = rb->read_ptr;  if (w > r) {    return ((r - w + rb->size) & rb->size_mask) - 1;  } else if (w < r) {    return (r - w) - 1;  } else {    return rb->size - 1;  }}/* The copying data reader.  Copy at most `cnt' bytes from `rb' to   `dest'.  Returns the actual number of bytes copied. */size_trb_read (rb_t * rb, char *dest, size_t cnt){  size_t free_cnt;  size_t cnt2;  size_t to_read;  size_t n1, n2;  if ((free_cnt = rb_read_space (rb)) == 0) {    return 0;  }  to_read = cnt > free_cnt ? free_cnt : cnt;  cnt2 = rb->read_ptr + to_read;  if (cnt2 > rb->size) {    n1 = rb->size - rb->read_ptr;    n2 = cnt2 & rb->size_mask;  } else {    n1 = to_read;    n2 = 0;  }  memcpy (dest, &(rb->buf[rb->read_ptr]), n1);  rb->read_ptr += n1;  rb->read_ptr &= rb->size_mask;  if (n2) {    memcpy (dest + n1, &(rb->buf[rb->read_ptr]), n2);    rb->read_ptr += n2;    rb->read_ptr &= rb->size_mask;  }  return to_read;}/* The copying data reader w/o read pointer advance.  Copy at most    `cnt' bytes from `rb' to `dest'.  Returns the actual number of bytes copied. */size_trb_peek (rb_t * rb, char *dest, size_t cnt){  size_t free_cnt;  size_t cnt2;  size_t to_read;  size_t n1, n2;  size_t tmp_read_ptr;  tmp_read_ptr = rb->read_ptr;  if ((free_cnt = rb_read_space (rb)) == 0) {    return 0;  }  to_read = cnt > free_cnt ? free_cnt : cnt;  cnt2 = tmp_read_ptr + to_read;  if (cnt2 > rb->size) {    n1 = rb->size - tmp_read_ptr;    n2 = cnt2 & rb->size_mask;  } else {    n1 = to_read;    n2 = 0;  }  memcpy (dest, &(rb->buf[tmp_read_ptr]), n1);  tmp_read_ptr += n1;  tmp_read_ptr &= rb->size_mask;  if (n2) {    memcpy (dest + n1, &(rb->buf[tmp_read_ptr]), n2);    tmp_read_ptr += n2;    tmp_read_ptr &= rb->size_mask;  }  return to_read;}/* The copying data writer.  Copy at most `cnt' bytes to `rb' from   `src'.  Returns the actual number of bytes copied. */size_trb_write (rb_t * rb, const char *src, size_t cnt){  size_t free_cnt;  size_t cnt2;  size_t to_write;  size_t n1, n2;  if ((free_cnt = rb_write_space (rb)) == 0) {    return 0;  }  to_write = cnt > free_cnt ? free_cnt : cnt;  cnt2 = rb->write_ptr + to_write;  if (cnt2 > rb->size) {    n1 = rb->size - rb->write_ptr;    n2 = cnt2 & rb->size_mask;  } else {    n1 = to_write;    n2 = 0;  }  memcpy (&(rb->buf[rb->write_ptr]), src, n1);  rb->write_ptr += n1;  rb->write_ptr &= rb->size_mask;  if (n2) {    memcpy (&(rb->buf[rb->write_ptr]), src + n1, n2);    rb->write_ptr += n2;    rb->write_ptr &= rb->size_mask;  }  return to_write;}/* Advance the read pointer `cnt' places. */voidrb_read_advance (rb_t * rb, size_t cnt){  rb->read_ptr += cnt;  rb->read_ptr &= rb->size_mask;}/* Advance the write pointer `cnt' places. */voidrb_write_advance (rb_t * rb, size_t cnt){  rb->write_ptr += cnt;  rb->write_ptr &= rb->size_mask;}/* The non-copying data reader.  `vec' is an array of two places.  Set   the values at `vec' to hold the current readable data at `rb'.  If   the readable data is in one segment the second segment has zero   length.  */voidrb_get_read_vector (const rb_t * rb,		    rb_data_t * vec){  size_t free_cnt;  size_t cnt2;  size_t w, r;  w = rb->write_ptr;  r = rb->read_ptr;  if (w > r) {    free_cnt = w - r;  } else {    free_cnt = (w - r + rb->size) & rb->size_mask;  }  cnt2 = r + free_cnt;  if (cnt2 > rb->size) {    /* Two part vector: the rest of the buffer after the current write       ptr, plus some from the start of the buffer. */    vec[0].buf = &(rb->buf[r]);    vec[0].len = rb->size - r;    vec[1].buf = rb->buf;    vec[1].len = cnt2 & rb->size_mask;  } else {    /* Single part vector: just the rest of the buffer */    vec[0].buf = &(rb->buf[r]);    vec[0].len = free_cnt;    vec[1].len = 0;  }}/* The non-copying data writer.  `vec' is an array of two places.  Set   the values at `vec' to hold the current writeable data at `rb'.  If   the writeable data is in one segment the second segment has zero   length.  */voidrb_get_write_vector (const rb_t * rb,		     rb_data_t * vec){  size_t free_cnt;  size_t cnt2;  size_t w, r;  w = rb->write_ptr;  r = rb->read_ptr;  if (w > r) {    free_cnt = ((r - w + rb->size) & rb->size_mask) - 1;  } else if (w < r) {    free_cnt = (r - w) - 1;  } else {    free_cnt = rb->size - 1;  }  cnt2 = w + free_cnt;  if (cnt2 > rb->size) {    /* Two part vector: the rest of the buffer after the current write       ptr, plus some from the start of the buffer. */    vec[0].buf = &(rb->buf[w]);    vec[0].len = rb->size - w;    vec[1].buf = rb->buf;    vec[1].len = cnt2 & rb->size_mask;  } else {    vec[0].buf = &(rb->buf[w]);    vec[0].len = free_cnt;    vec[1].len = 0;  }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩国产三级| 午夜精品福利久久久| 亚洲一区二区美女| 国产一区二区三区免费在线观看| 在线观看欧美黄色| 国产色综合一区| 日av在线不卡| 精品视频在线免费| 亚洲美女一区二区三区| 国产在线播放一区| 欧美一区二区三区色| 亚洲欧洲性图库| 国产成人超碰人人澡人人澡| 日韩欧美国产成人一区二区| 一区二区欧美在线观看| www.欧美色图| 欧美激情综合五月色丁香 | 美日韩一区二区| 91麻豆蜜桃一区二区三区| 精品国精品自拍自在线| 日本成人中文字幕在线视频| 欧美日韩小视频| 亚洲成a人片综合在线| 欧美久久一区二区| 亚洲国产精品久久人人爱蜜臀| 91免费看`日韩一区二区| 国产精品久久看| 97精品久久久久中文字幕| 中文字幕一区二区日韩精品绯色| 国产乱码一区二区三区| 久久久91精品国产一区二区三区| 韩国成人在线视频| 久久九九久精品国产免费直播| 精品一区二区在线看| 欧美成人精品二区三区99精品| 蜜臀av性久久久久蜜臀av麻豆| 69精品人人人人| 久久99热这里只有精品| 精品国产电影一区二区| 国产东北露脸精品视频| 中文字幕av一区 二区| zzijzzij亚洲日本少妇熟睡| 亚洲人成影院在线观看| 91老司机福利 在线| 亚洲综合一区二区三区| 欧美日韩亚洲综合在线| 视频一区二区三区在线| 欧美成人三级在线| 国产成人av自拍| 一区二区三区四区在线播放| 欧美精品v国产精品v日韩精品| 麻豆精品在线观看| 中文字幕乱码亚洲精品一区| av电影一区二区| 天天色综合天天| 欧美mv日韩mv国产网站app| 国产盗摄精品一区二区三区在线| 亚洲色图在线播放| 91精品国产综合久久蜜臀 | 精品视频一区二区三区免费| 水野朝阳av一区二区三区| 精品久久国产97色综合| 91小视频免费看| 日产欧产美韩系列久久99| 久久一二三国产| 91激情五月电影| 国产资源在线一区| 亚洲黄色在线视频| 久久亚洲影视婷婷| 91福利国产精品| 国产河南妇女毛片精品久久久| 亚洲精品乱码久久久久| 亚洲精品一区二区三区蜜桃下载| 91片在线免费观看| 极品少妇一区二区| 亚洲宅男天堂在线观看无病毒| 欧美精品一区二区三| 日本精品免费观看高清观看| 黄页网站大全一区二区| 亚洲成人动漫在线免费观看| 久久久国产精品不卡| 欧美片在线播放| 99精品视频中文字幕| 九色|91porny| 天天综合色天天| 日韩理论电影院| 中文字幕不卡在线播放| 欧美大片在线观看| 欧美日韩一区三区| 精品国内二区三区| 欧美精品在线观看一区二区| 成人a区在线观看| 国产一区二区精品在线观看| 男男视频亚洲欧美| 亚洲制服欧美中文字幕中文字幕| 中文字幕不卡在线| 久久久久久影视| 精品免费视频.| 91精品国产色综合久久ai换脸| 91尤物视频在线观看| 国产成人精品亚洲777人妖| 久久国产精品区| 蜜桃视频一区二区| 日韩在线卡一卡二| 亚洲成人激情综合网| 一区二区三区中文字幕在线观看| 国产精品入口麻豆原神| 国产欧美一区二区精品性| 欧美不卡一区二区| 日韩欧美一区二区三区在线| 精品视频1区2区| 欧美日本韩国一区二区三区视频| 日本精品免费观看高清观看| 91久久香蕉国产日韩欧美9色| 99精品视频在线观看| aaa欧美日韩| 91色porny| 欧美色综合影院| 欧美日韩视频在线一区二区| 91福利视频久久久久| 欧美四级电影在线观看| 欧美视频完全免费看| 91麻豆精品国产无毒不卡在线观看| 欧美二区乱c少妇| 欧美成人精品福利| 国产人妖乱国产精品人妖| 日本一区二区动态图| 日韩美女久久久| 亚洲丶国产丶欧美一区二区三区| 午夜精品福利一区二区三区蜜桃| 99视频有精品| 日本精品视频一区二区| 欧美高清精品3d| 久久久www免费人成精品| 国产精品人人做人人爽人人添| 亚洲视频资源在线| 亚洲3atv精品一区二区三区| 美女www一区二区| 处破女av一区二区| 在线观看国产日韩| 日韩欧美国产综合在线一区二区三区 | 91黄色免费版| 欧美一三区三区四区免费在线看| 欧美本精品男人aⅴ天堂| 国产精品午夜在线观看| 亚洲综合丝袜美腿| 国产制服丝袜一区| 色欲综合视频天天天| 欧美电影免费观看高清完整版在线观看 | 中文在线一区二区| 亚洲国产另类av| 国产剧情一区二区三区| 色屁屁一区二区| 久久久久99精品国产片| 亚洲美女淫视频| 精品一区二区三区香蕉蜜桃| 91亚洲国产成人精品一区二三| 91精品国产综合久久香蕉麻豆| 国产精品久久夜| 欧美aⅴ一区二区三区视频| 99视频超级精品| 亚洲一区二区成人在线观看| 久久黄色级2电影| 欧美在线免费视屏| 中文久久乱码一区二区| 日韩电影在线观看网站| 91免费国产在线观看| 久久婷婷成人综合色| 婷婷中文字幕一区三区| 99久久久精品| 国产日韩欧美综合在线| 日本不卡一二三| 欧美视频一区二区三区| 自拍视频在线观看一区二区| 国产一区二区美女| 日韩一级片在线播放| 亚洲一区在线观看免费观看电影高清 | 日韩欧美中文字幕一区| 亚洲影视在线播放| 91啪在线观看| 中文字幕乱码日本亚洲一区二区| 捆绑调教美女网站视频一区| 欧美日韩国产片| 一区二区三区加勒比av| av一区二区久久| 国产精品午夜久久| 久久精品国产免费| 91精品国产一区二区三区| 亚洲福利电影网| 在线观看国产一区二区| 亚洲综合久久久久| 色屁屁一区二区| 亚洲国产毛片aaaaa无费看| 在线精品视频免费播放| 一区二区三区四区精品在线视频| 91在线播放网址| 夜色激情一区二区| 欧美在线你懂的| 婷婷亚洲久悠悠色悠在线播放| 欧美日韩国产a|