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

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

?? os_os2.c

?? 嵌入式數據系統軟件!
?? C
?? 第 1 頁 / 共 3 頁
字號:
    }  }  /* Acquire a shared lock  */  if( locktype==SHARED_LOCK && res == NO_ERROR ){    assert( pFile->locktype==NO_LOCK );    res = getReadLock(pFile);    if( res == NO_ERROR ){      newLocktype = SHARED_LOCK;    }    OSTRACE3( "LOCK %d acquire shared lock. res=%d\n", pFile->h, res );  }  /* Acquire a RESERVED lock  */  if( locktype==RESERVED_LOCK && res == NO_ERROR ){    assert( pFile->locktype==SHARED_LOCK );    LockArea.lOffset = RESERVED_BYTE;    LockArea.lRange = 1L;    UnlockArea.lOffset = 0L;    UnlockArea.lRange = 0L;    res = DosSetFileLocks( pFile->h, &UnlockArea, &LockArea, 2000L, 1L );    if( res == NO_ERROR ){      newLocktype = RESERVED_LOCK;    }    OSTRACE3( "LOCK %d acquire reserved lock. res=%d\n", pFile->h, res );  }  /* Acquire a PENDING lock  */  if( locktype==EXCLUSIVE_LOCK && res == NO_ERROR ){    newLocktype = PENDING_LOCK;    gotPendingLock = 0;    OSTRACE2( "LOCK %d acquire pending lock. pending lock boolean unset.\n", pFile->h );  }  /* Acquire an EXCLUSIVE lock  */  if( locktype==EXCLUSIVE_LOCK && res == NO_ERROR ){    assert( pFile->locktype>=SHARED_LOCK );    res = unlockReadLock(pFile);    OSTRACE2( "unreadlock = %d\n", res );    LockArea.lOffset = SHARED_FIRST;    LockArea.lRange = SHARED_SIZE;    UnlockArea.lOffset = 0L;    UnlockArea.lRange = 0L;    res = DosSetFileLocks( pFile->h, &UnlockArea, &LockArea, 2000L, 1L );    if( res == NO_ERROR ){      newLocktype = EXCLUSIVE_LOCK;    }else{      OSTRACE2( "OS/2 error-code = %d\n", res );      getReadLock(pFile);    }    OSTRACE3( "LOCK %d acquire exclusive lock.  res=%d\n", pFile->h, res );  }  /* If we are holding a PENDING lock that ought to be released, then  ** release it now.  */  if( gotPendingLock && locktype==SHARED_LOCK ){    int r;    LockArea.lOffset = 0L;    LockArea.lRange = 0L;    UnlockArea.lOffset = PENDING_BYTE;    UnlockArea.lRange = 1L;    r = DosSetFileLocks( pFile->h, &UnlockArea, &LockArea, 2000L, 1L );    OSTRACE3( "LOCK %d unlocking pending/is shared. r=%d\n", pFile->h, r );  }  /* Update the state of the lock has held in the file descriptor then  ** return the appropriate result code.  */  if( res == NO_ERROR ){    rc = SQLITE_OK;  }else{    OSTRACE4( "LOCK FAILED %d trying for %d but got %d\n", pFile->h,              locktype, newLocktype );    rc = SQLITE_BUSY;  }  pFile->locktype = newLocktype;  OSTRACE3( "LOCK %d now %d\n", pFile->h, pFile->locktype );  return rc;}/*** This routine checks if there is a RESERVED lock held on the specified** file by this or any other process. If such a lock is held, return** non-zero, otherwise zero.*/int os2CheckReservedLock( sqlite3_file *id ){  APIRET rc = NO_ERROR;  os2File *pFile = (os2File*)id;  assert( pFile!=0 );  if( pFile->locktype>=RESERVED_LOCK ){    rc = 1;    OSTRACE3( "TEST WR-LOCK %d %d (local)\n", pFile->h, rc );  }else{    FILELOCK  LockArea,              UnlockArea;    memset(&LockArea, 0, sizeof(LockArea));    memset(&UnlockArea, 0, sizeof(UnlockArea));    LockArea.lOffset = RESERVED_BYTE;    LockArea.lRange = 1L;    UnlockArea.lOffset = 0L;    UnlockArea.lRange = 0L;    rc = DosSetFileLocks( pFile->h, &UnlockArea, &LockArea, 2000L, 1L );    OSTRACE3( "TEST WR-LOCK %d lock reserved byte rc=%d\n", pFile->h, rc );    if( rc == NO_ERROR ){      int r;      LockArea.lOffset = 0L;      LockArea.lRange = 0L;      UnlockArea.lOffset = RESERVED_BYTE;      UnlockArea.lRange = 1L;      r = DosSetFileLocks( pFile->h, &UnlockArea, &LockArea, 2000L, 1L );      OSTRACE3( "TEST WR-LOCK %d unlock reserved byte r=%d\n", pFile->h, r );    }    OSTRACE3( "TEST WR-LOCK %d %d (remote)\n", pFile->h, rc );  }  return rc;}/*** Lower the locking level on file descriptor id to locktype.  locktype** must be either NO_LOCK or SHARED_LOCK.**** If the locking level of the file descriptor is already at or below** the requested locking level, this routine is a no-op.**** It is not possible for this routine to fail if the second argument** is NO_LOCK.  If the second argument is SHARED_LOCK then this routine** might return SQLITE_IOERR;*/int os2Unlock( sqlite3_file *id, int locktype ){  int type;  os2File *pFile = (os2File*)id;  APIRET rc = SQLITE_OK;  APIRET res = NO_ERROR;  FILELOCK  LockArea,            UnlockArea;  memset(&LockArea, 0, sizeof(LockArea));  memset(&UnlockArea, 0, sizeof(UnlockArea));  assert( pFile!=0 );  assert( locktype<=SHARED_LOCK );  OSTRACE4( "UNLOCK %d to %d was %d\n", pFile->h, locktype, pFile->locktype );  type = pFile->locktype;  if( type>=EXCLUSIVE_LOCK ){    LockArea.lOffset = 0L;    LockArea.lRange = 0L;    UnlockArea.lOffset = SHARED_FIRST;    UnlockArea.lRange = SHARED_SIZE;    res = DosSetFileLocks( pFile->h, &UnlockArea, &LockArea, 2000L, 1L );    OSTRACE3( "UNLOCK %d exclusive lock res=%d\n", pFile->h, res );    if( locktype==SHARED_LOCK && getReadLock(pFile) != NO_ERROR ){      /* This should never happen.  We should always be able to      ** reacquire the read lock */      OSTRACE3( "UNLOCK %d to %d getReadLock() failed\n", pFile->h, locktype );      rc = SQLITE_IOERR_UNLOCK;    }  }  if( type>=RESERVED_LOCK ){    LockArea.lOffset = 0L;    LockArea.lRange = 0L;    UnlockArea.lOffset = RESERVED_BYTE;    UnlockArea.lRange = 1L;    res = DosSetFileLocks( pFile->h, &UnlockArea, &LockArea, 2000L, 1L );    OSTRACE3( "UNLOCK %d reserved res=%d\n", pFile->h, res );  }  if( locktype==NO_LOCK && type>=SHARED_LOCK ){    res = unlockReadLock(pFile);    OSTRACE5( "UNLOCK %d is %d want %d res=%d\n", pFile->h, type, locktype, res );  }  if( type>=PENDING_LOCK ){    LockArea.lOffset = 0L;    LockArea.lRange = 0L;    UnlockArea.lOffset = PENDING_BYTE;    UnlockArea.lRange = 1L;    res = DosSetFileLocks( pFile->h, &UnlockArea, &LockArea, 2000L, 1L );    OSTRACE3( "UNLOCK %d pending res=%d\n", pFile->h, res );  }  pFile->locktype = locktype;  OSTRACE3( "UNLOCK %d now %d\n", pFile->h, pFile->locktype );  return rc;}/*** Control and query of the open file handle.*/static int os2FileControl(sqlite3_file *id, int op, void *pArg){  switch( op ){    case SQLITE_FCNTL_LOCKSTATE: {      *(int*)pArg = ((os2File*)id)->locktype;      OSTRACE3( "FCNTL_LOCKSTATE %d lock=%d\n", ((os2File*)id)->h, ((os2File*)id)->locktype );      return SQLITE_OK;    }  }  return SQLITE_ERROR;}/*** Return the sector size in bytes of the underlying block device for** the specified file. This is almost always 512 bytes, but may be** larger for some devices.**** SQLite code assumes this function cannot fail. It also assumes that** if two files are created in the same file-system directory (i.e.** a database and its journal file) that the sector size will be the** same for both.*/static int os2SectorSize(sqlite3_file *id){  return SQLITE_DEFAULT_SECTOR_SIZE;}/*** Return a vector of device characteristics.*/static int os2DeviceCharacteristics(sqlite3_file *id){  return 0;}/*** This vector defines all the methods that can operate on an** sqlite3_file for os2.*/static const sqlite3_io_methods os2IoMethod = {  1,                        /* iVersion */  os2Close,  os2Read,  os2Write,  os2Truncate,  os2Sync,  os2FileSize,  os2Lock,  os2Unlock,  os2CheckReservedLock,  os2FileControl,  os2SectorSize,  os2DeviceCharacteristics};/***************************************************************************** Here ends the I/O methods that form the sqlite3_io_methods object.**** The next block of code implements the VFS methods.****************************************************************************//*** Open a file.*/static int os2Open(  sqlite3_vfs *pVfs,            /* Not used */  const char *zName,            /* Name of the file */  sqlite3_file *id,             /* Write the SQLite file handle here */  int flags,                    /* Open mode flags */  int *pOutFlags                /* Status return flags */){  HFILE h;  ULONG ulFileAttribute = 0;  ULONG ulOpenFlags = 0;  ULONG ulOpenMode = 0;  os2File *pFile = (os2File*)id;  APIRET rc = NO_ERROR;  ULONG ulAction;  memset(pFile, 0, sizeof(*pFile));  OSTRACE2( "OPEN want %d\n", flags );  //ulOpenMode = flags & SQLITE_OPEN_READWRITE ? OPEN_ACCESS_READWRITE : OPEN_ACCESS_READONLY;  if( flags & SQLITE_OPEN_READWRITE ){    ulOpenMode |= OPEN_ACCESS_READWRITE;    OSTRACE1( "OPEN read/write\n" );  }else{    ulOpenMode |= OPEN_ACCESS_READONLY;    OSTRACE1( "OPEN read only\n" );  }  //ulOpenFlags = flags & SQLITE_OPEN_CREATE ? OPEN_ACTION_CREATE_IF_NEW : OPEN_ACTION_FAIL_IF_NEW;  if( flags & SQLITE_OPEN_CREATE ){    ulOpenFlags |= OPEN_ACTION_OPEN_IF_EXISTS | OPEN_ACTION_CREATE_IF_NEW;    OSTRACE1( "OPEN open new/create\n" );  }else{    ulOpenFlags |= OPEN_ACTION_OPEN_IF_EXISTS | OPEN_ACTION_FAIL_IF_NEW;    OSTRACE1( "OPEN open existing\n" );  }  //ulOpenMode |= flags & SQLITE_OPEN_MAIN_DB ? OPEN_SHARE_DENYNONE : OPEN_SHARE_DENYWRITE;  if( flags & SQLITE_OPEN_MAIN_DB ){    ulOpenMode |= OPEN_SHARE_DENYNONE;    OSTRACE1( "OPEN share read/write\n" );  }else{    ulOpenMode |= OPEN_SHARE_DENYWRITE;    OSTRACE1( "OPEN share read only\n" );  }  if( flags & (SQLITE_OPEN_TEMP_DB | SQLITE_OPEN_TEMP_JOURNAL               | SQLITE_OPEN_SUBJOURNAL) ){    //ulFileAttribute = FILE_HIDDEN;  //for debugging, we want to make sure it is deleted    ulFileAttribute = FILE_NORMAL;    pFile->delOnClose = 1;    pFile->pathToDel = (char*)malloc(sizeof(char) * pVfs->mxPathname);    sqlite3OsFullPathname(pVfs, zName, pVfs->mxPathname, pFile->pathToDel);    OSTRACE1( "OPEN hidden/delete on close file attributes\n" );  }else{    ulFileAttribute = FILE_ARCHIVED | FILE_NORMAL;    pFile->delOnClose = 0;    pFile->pathToDel = NULL;    OSTRACE1( "OPEN normal file attribute\n" );  }  //ulOpenMode |= flags & (SQLITE_OPEN_MAIN_DB | SQLITE_OPEN_TEMP_DB) ?  //                  OPEN_FLAGS_RANDOM : OPEN_FLAGS_SEQUENTIAL;  if( flags & (SQLITE_OPEN_MAIN_DB | SQLITE_OPEN_TEMP_DB) ){    ulOpenMode |= OPEN_FLAGS_RANDOM;    OSTRACE1( "OPEN random access\n" );  }else{    ulOpenMode |= OPEN_FLAGS_SEQUENTIAL;    OSTRACE1( "OPEN sequential access\n" );  }  ulOpenMode |= OPEN_FLAGS_FAIL_ON_ERROR;  rc = DosOpen( (PSZ)zName,                &h,                &ulAction,                0L,                ulFileAttribute,                ulOpenFlags,                ulOpenMode,                (PEAOP2)NULL );  if( rc != NO_ERROR ){    OSTRACE7( "OPEN Invalid handle rc=%d: zName=%s, ulAction=%#lx, ulAttr=%#lx, ulFlags=%#lx, ulMode=%#lx\n",              rc, zName, ulAction, ulFileAttribute, ulOpenFlags, ulOpenMode );    if( flags & SQLITE_OPEN_READWRITE ){      OSTRACE2( "OPEN %d Invalid handle\n", ((flags | SQLITE_OPEN_READONLY) & ~SQLITE_OPEN_READWRITE) );      return os2Open( 0, zName, id,                      ((flags | SQLITE_OPEN_READONLY) & ~SQLITE_OPEN_READWRITE),                      pOutFlags );    }else{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区免费| 久久香蕉国产线看观看99| 国产亚洲一区二区三区在线观看| 亚洲男女一区二区三区| 久88久久88久久久| 欧美日韩在线直播| 亚洲欧洲精品天堂一级| 精品在线亚洲视频| 欧美三区在线视频| 亚洲欧美另类小说| 国产suv精品一区二区三区| 91精品国产综合久久精品| 亚洲男人电影天堂| 成人免费看片app下载| 日韩欧美亚洲国产精品字幕久久久| 亚洲精品成人在线| 成人精品国产一区二区4080| 精品入口麻豆88视频| 五月婷婷综合网| 色综合亚洲欧洲| 欧美国产日韩精品免费观看| 久久精品久久综合| 欧美精选午夜久久久乱码6080| 亚洲欧美日本韩国| www.在线欧美| 国产精品三级久久久久三级| 国产真实乱对白精彩久久| 91麻豆精品国产自产在线观看一区| 亚洲午夜精品久久久久久久久| 色偷偷久久一区二区三区| 欧美激情一区在线观看| 国产精品影视在线观看| 亚洲精品一区二区三区香蕉| 蜜桃视频一区二区| 欧美一区二区三区免费在线看| 亚洲成a人v欧美综合天堂| 色老头久久综合| 亚洲视频在线观看三级| 99免费精品视频| 中文字幕在线一区免费| 成人av免费网站| 国产精品第四页| a美女胸又www黄视频久久| 综合网在线视频| 国产日产欧美一区二区视频| 国产一区在线观看视频| 久久―日本道色综合久久| 国产原创一区二区| 国产亚洲一二三区| 成人视屏免费看| 成人免费在线视频| 99久久免费国产| 一区二区三区中文字幕精品精品| 91日韩精品一区| 樱桃视频在线观看一区| 在线观看日韩高清av| 亚洲国产sm捆绑调教视频 | 亚洲中国最大av网站| 日本国产一区二区| 亚洲18色成人| 日韩精品专区在线影院观看| 精品亚洲国内自在自线福利| 久久网站最新地址| 国产精品18久久久| 亚洲欧美日韩国产一区二区三区| 色哟哟欧美精品| 三级不卡在线观看| 精品国产凹凸成av人网站| 国产91色综合久久免费分享| 中文字幕亚洲不卡| 欧美无砖专区一中文字| 日本91福利区| 日本一区二区三区在线观看| 色综合久久久久网| 午夜久久久久久久久| 精品国产精品一区二区夜夜嗨 | 亚洲男同性视频| 欧美三级三级三级爽爽爽| 蜜桃视频在线观看一区二区| 国产午夜精品在线观看| 色久综合一二码| 奇米色一区二区| 国产精品天天摸av网| 欧美亚洲国产一区二区三区va| 日本欧美久久久久免费播放网| 久久精品人人做人人爽人人| 色综合久久久久网| 久久99国产精品久久99| 亚洲视频一区二区在线| 欧美一级免费大片| kk眼镜猥琐国模调教系列一区二区 | 岛国精品在线播放| 亚洲bdsm女犯bdsm网站| 国产午夜精品在线观看| 欧美色图激情小说| 国产精品一区二区三区99| 一区二区三区**美女毛片| 精品国一区二区三区| 日本乱人伦aⅴ精品| 国内一区二区视频| 亚洲在线观看免费视频| 国产日韩欧美精品一区| 欧美人妇做爰xxxⅹ性高电影| 国产美女一区二区| 午夜伦理一区二区| 亚洲欧洲国产日本综合| 日韩欧美一级二级三级| 色婷婷久久综合| 国产乱国产乱300精品| 亚洲成人动漫精品| 国产精品国产三级国产aⅴ原创| 日韩一区二区麻豆国产| 色综合久久综合网欧美综合网| 久久99久久99小草精品免视看| 一区二区三区资源| 欧美韩国日本综合| 日韩欧美成人一区| 在线观看视频一区二区| 粉嫩绯色av一区二区在线观看| 秋霞电影一区二区| 亚洲午夜免费电影| 中文字幕一区二区视频| 精品国产91洋老外米糕| 欧美三级三级三级爽爽爽| 99久免费精品视频在线观看 | 亚洲女女做受ⅹxx高潮| 国产校园另类小说区| 日韩精品资源二区在线| 欧美酷刑日本凌虐凌虐| 91视频你懂的| 福利一区二区在线| 六月丁香婷婷久久| 五月天精品一区二区三区| 一区二区三区在线免费观看| 欧美高清在线一区| 久久免费电影网| 91精品免费在线观看| 欧美三级电影在线观看| 91色综合久久久久婷婷| 成人午夜视频免费看| 国产精品99久久久久久久女警| 裸体一区二区三区| 日韩国产在线观看| 亚洲成a人v欧美综合天堂下载| 亚洲精品久久久蜜桃| 亚洲三级理论片| 中文字幕不卡在线播放| 国产色爱av资源综合区| 精品国产区一区| 亚洲精品在线三区| 精品免费视频.| 精品国产伦一区二区三区观看方式| 欧美一区二区黄色| 欧美一区午夜视频在线观看| 欧美丰满少妇xxxxx高潮对白| 欧美日韩午夜精品| 欧美揉bbbbb揉bbbbb| 欧美撒尿777hd撒尿| 欧美日韩一区二区三区免费看| 欧美色大人视频| 欧美日韩另类一区| 91精品国产91综合久久蜜臀| 欧美一区二区久久久| 欧美v亚洲v综合ⅴ国产v| 欧美成人高清电影在线| 精品国产露脸精彩对白| 久久影音资源网| 国产欧美一区二区三区鸳鸯浴| 欧美激情一区三区| 日韩理论片中文av| 亚洲精品国产视频| 午夜不卡在线视频| 蜜桃传媒麻豆第一区在线观看| 激情欧美一区二区| 丁香婷婷综合色啪| 99精品在线观看视频| 色香蕉成人二区免费| 欧美人与禽zozo性伦| 日韩午夜精品视频| 久久免费精品国产久精品久久久久 | 国产成人免费xxxxxxxx| 成人av在线一区二区| 色婷婷亚洲综合| 欧美精品日韩一本| 精品国产乱子伦一区| 久久久久国产精品麻豆ai换脸| 中文字幕视频一区二区三区久| 亚洲永久免费视频| 毛片av一区二区三区| 国产精品1区2区| 色一区在线观看| 91精品国产一区二区三区香蕉| 日韩女优av电影| 国产精品免费av| 亚洲成人精品在线观看| 蜜桃精品在线观看| av电影在线观看一区| 欧美日韩国产小视频| 久久久久久一级片| 亚洲一区二区在线免费观看视频|