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

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

?? tm1stuff.c

?? PNX系列設備驅動 PNX系列設備驅動
?? C
?? 第 1 頁 / 共 3 頁
字號:
	if (fd == STDERR_HANDLE && stderr_fd != STDERR_HANDLE)
		fd = stderr_fd;
	
    if (  fd == STDOUT_HANDLE 
       || fd == STDERR_HANDLE 
       ) {
        int i;
        for (i=0; i<n; i++) {
            if (buf[i] == 0x0a) buf[i]= 0x0d;
        }
    }
    
    return write(fd,buf,n);
}


static int my_open_dll( char *name )
{
    return OpenDll_open_dll(name, (RPCServ_OpenFunc) open, object_endian);
}

Boolean StartTM(Int32 node)
{
#ifdef DEBUG
	printf("Starting node %d\n", node);
#endif

    if (!CommBufferClean) {
	  _HostCall_commvar[0]= 0;
	  _HostCall_commvar[1]= 0;
	  _HostCall_commvar[2]= 0;
	  _HostCall_commvar[3]= 0;
      CommBufferClean = True;
    }
    
    // strange?
    MMIO_M(node,BIU_CTL) |= SET_RST_MASK;
    MMIO_M(node,BIU_CTL) &= ~SET_RST_MASK;
        
    // This takes TM out of reset
    MMIO_M(node,BIU_CTL) |= CLEAR_RST_MASK;
    
    MMIO_M(node,SEM) = 0;
    
    TMInfo[node].TM_running = true;
    
    return true;
}

void StartTMHostComm(void)
{

    CommBufferClean = False;
    TM1IF_start_serving();
}

OSStatus GetRevisionID(const RegEntryID *theEntry, UInt32* revision_id);
OSStatus GetRevisionID(const RegEntryID *theEntry, UInt32* revision_id)
{
	OSStatus 				err;
	RegPropertyValueSize	SizeOfProp;
	void			 		*propValue;
	
	err = RegistryPropertyGetSize(theEntry, "revision-id", &SizeOfProp);							/* need node's reg property size */
	if (err == noErr)
	{		
		propValue = NULL;																	/* allocate space for a local variable */
		propValue = NewPtr(SizeOfProp);														/* in Memory.h */
		if (propValue == NULL)
		{
			printf("\nERROR: No memory available to store property value.\n");
			return -1;
		}
		err = RegistryPropertyGet(theEntry, "revision-id", propValue, &SizeOfProp);		/* get the name value */
		if (err != noErr)
			return err;
//		printf("0x%x\n", * (UInt32*) propValue);	
		*revision_id = *(UInt32*)propValue;	
		
	}	
	return err;
}

//===================================================================
//===================================================================
OSStatus
GetDeviceProperty( RegEntryID *pRegID, RegPropertyName *pPropertyName, 
					RegPropertyValue *pPropertyValue, RegPropertyValueSize *pPropertySize );
OSStatus
GetDeviceProperty( RegEntryID *pRegID, RegPropertyName *pPropertyName, 
					RegPropertyValue *pPropertyValue, RegPropertyValueSize *pPropertySize )
{ 
	OSStatus	err = noErr;
	
	/*
	 * Get the size of the value first to see if our buffer is big enough.
	 */
	err = RegistryPropertyGetSize( pRegID, pPropertyName, pPropertySize );
	if ( err == noErr )
	{
		*pPropertyValue = (RegPropertyValue) malloc( *pPropertySize );
		/*
		 * Note, we return the actual property size.
		 */
		err = RegistryPropertyGet( pRegID, pPropertyName, *pPropertyValue, pPropertySize );
	}
	
	return err;
}

//===================================================================
//===================================================================
OSStatus
DisposeProperty( RegPropertyValue propertyValue );
OSStatus
DisposeProperty( RegPropertyValue propertyValue )
{
	if (propertyValue)
		free( propertyValue );
	return noErr;
}

//===================================================================
//===================================================================
OSStatus
GetBaseAddress( RegEntryID *pRegID, UInt32 *pBaseRegAddress,
				UInt8 offsetValue, UInt32 *pSpaceAllocated );
OSStatus
GetBaseAddress( RegEntryID *pRegID, UInt32 *pBaseRegAddress,
				UInt8 offsetValue, UInt32 *pSpaceAllocated )
{
	OSStatus				osStatus;
	PCIAssignedAddress		*pAssignedArray;
	RegPropertyValueSize	propertySize;
	UInt32					numberOfElements, *pVirtualArray;
	Boolean					foundMatch;
	UInt16					index;
		
	*pBaseRegAddress = NULL; // default value
	foundMatch = false;
	
	osStatus = GetDeviceProperty( pRegID, kPCIAssignedAddressProperty,
										&pAssignedArray, &propertySize);

	if ( (osStatus == noErr) && propertySize )
	{
		numberOfElements = propertySize/sizeof(PCIAssignedAddress);
		
		osStatus = GetDeviceProperty( pRegID, kAAPLDeviceLogicalAddress,
											&pVirtualArray, &propertySize);

		if ( (osStatus == noErr) && propertySize )
		{
			// search through the assigned addresses property looking for base register
			for (index = 0; (index != numberOfElements) && !foundMatch; ++index)
			{
				if (pAssignedArray[index].registerNumber == offsetValue)
				{
					if ( pSpaceAllocated )
						*pSpaceAllocated = pAssignedArray[index].size.lo;
					if ( pBaseRegAddress ) {
						if ( pVirtualArray[index] == nil ) {
							*pBaseRegAddress = pAssignedArray[index].address.lo;
						} else {
							*pBaseRegAddress = pVirtualArray[index];
						}
					}
					foundMatch = true;
				}
			}
		
			DisposeProperty( pVirtualArray );
		}
		else
			if ( osStatus != noErr )
				osStatus = nrInvalidNodeErr;
	
		DisposeProperty( pAssignedArray );
	}
	else
		if ( osStatus != noErr )
			osStatus = nrInvalidNodeErr;
		
	return osStatus;
}

// ------------------------------------------------
// FindPropertyWithValue
// 	Find a node with a specific property and value in the Registry
// jdb: propertyNamePtr is the string to match
//		propertyValue is the value of the property
//		foundEntry is the returned node id.
//		returns:	1.  noErr if foundEntry is updated
//				2.  done if done is true (got to end of device tree and didn't find property)
//			      	3.  an error if Registry routines return an error.
// ------------------------------------------------

OSStatus FindPropertyWithValue(const RegPropertyName *propertyName, const void *propertyValue, 
                               const RegPropertyValueSize propertySize, RegEntryID *foundEntry);
OSStatus FindPropertyWithValue(const RegPropertyName *propertyName, const void *propertyValue, 
                               const RegPropertyValueSize propertySize, RegEntryID *foundEntry)
{
	RegEntryIter 		cookie; 
	RegEntryID 		theEntry; 
	RegEntryIterationOp 	iterOp; 
	Boolean 		done; 
	OSStatus 		err = noErr;

	RegistryEntryIDInit(&theEntry);

	err = RegistryEntryIterateCreate(&cookie); 
	if (err != noErr) 
		return err;

	iterOp = kRegIterContinue; 

	err = RegistryEntrySearch(&cookie, iterOp, &theEntry, &done, 
				  propertyName, propertyValue, propertySize);

	if (!done && (err == noErr)) 
	{ 
		*foundEntry = theEntry; 
	}
	else if (done) 
		err = done; 

	RegistryEntryIDDispose(&theEntry); 
	RegistryEntryIterateDispose(&cookie);
	 
	return err; 
}

/* Slight misnomer since GetTMPreferences() also creates one if it's missing. */

Boolean GetTMPreference(const char * name, char * value) 
{
  OSErr err;
  short myVRef;
  FSSpec mySpec;
  char* myBuffer ;
  short myRefNum, myVol;
  long int myDirID;
  long int myLength = strlen((const char*) PREFERENCES);
  long int i,j, k;
  int found = false;
  int length;
    
  if (name == NULL || value == NULL) return false;
  
  err = FindFolder(kOnSystemDisk, kPreferencesFolderType, kCreateFolder, &myVRef, &myDirID);
  if(err != noErr) {
    printf("Cannot find preference folder (%d)\n", err);
    return false;
  }
  
  err = FSMakeFSSpec(myVRef, myDirID, P_PREFERENCE_FILE, &mySpec);
  if(err == fnfErr) {
    /* file not found, so generate one */
    err = FSpCreate(&mySpec, 'ttxt', 'TEXT', smSystemScript);
    if(err != noErr) {
      printf("Cannot create preference file %s (%d)\n", C_PREFERENCE_FILE, err);
      return false;
    }
    err = FSpOpenDF(&mySpec, fsRdWrPerm, &myRefNum);
    if(err != noErr) {
      printf("Cannot open preference file %s after creation (%d)\n", C_PREFERENCE_FILE, err);
      return false;
    }
    err = SetFPos(myRefNum, fsFromStart, 0);
    if(err != noErr) {
      printf("Cannot set position in preference file %s (%d)\n", C_PREFERENCE_FILE, err);
      return false;
    }
    err = FSWrite(myRefNum, &myLength, PREFERENCES);
    if(err != noErr) {
      printf("Cannot write to preference file %s (%d)\n", C_PREFERENCE_FILE, err);
      return false;
    }
    err = SetEOF(myRefNum, myLength);
    if(err != noErr) {
      printf("Cannot set EOF in preference file %s (%d)\n", C_PREFERENCE_FILE, err);
      return false;
    }
    err = GetVRefNum(myRefNum, &myVol);
    if(err != noErr) {
      printf("Cannot get volume of preference file %s (%d)\n", C_PREFERENCE_FILE, err);
      return false;
    }
    err = FlushVol(Null, myVol);
    if(err != noErr) {
      printf("Cannot flush preference file %s (%d)\n", C_PREFERENCE_FILE, err);
      return false;
    }
    err = FSClose(myRefNum);  
    if(err != noErr) {
      printf("Cannot close preference file %s (%d)\n", C_PREFERENCE_FILE, err);
    }
    printf("Created default '" C_PREFERENCE_FILE "' file in the Preferences folder.\n");
  }
  else if (err != noErr) {
    printf("Cannot find preference file %s or something (%d)\n", C_PREFERENCE_FILE, err);
    return false;
  }

  err = FSpOpenDF(&mySpec, fsCurPerm, &myRefNum);
  if(err != noErr) {
    printf("Cannot find preference file %s or something (%d)\n", C_PREFERENCE_FILE, err);
    return false;
  }
  err = GetEOF(myRefNum, &myLength);
  if(err != noErr) {
    printf("Cannot get length of preference file %s (%d)\n", C_PREFERENCE_FILE, err);
    return false;
  }
  
  myBuffer =  (char*) NewPtr(myLength);
  if(myBuffer == NULL) {
    printf("Cannot allocate enough memory\n");
    return false;
  }
  err = FSRead(myRefNum, &myLength, myBuffer);
  if(err != noErr) {
    printf("Cannot read preference file %s (%d)\n", C_PREFERENCE_FILE, err);
    return false;
  }
  
  i = 0;
  length = strlen(name); 

  while (i < myLength) {
    /* check whether we see the correct attribute */
    if (strncmp(name, myBuffer+i, length) == 0) {
       /* check whether we see a '=' now */
       if (myBuffer[i + length] == '=') {
         /* set the cursor j just after the '=' */
         j = i + length + 1;
         k = 0;
         found = true;
         /* and copy everything until newline (in MPW/Mac way) or end of file */
         while (myBuffer[j] != '\n' && myBuffer[j] != '\r' && j < myLength) 
           value[k++] = myBuffer[j++];
         value[k] = '\0';
         /* break out the while */
         break;
       }
       /* else printf("almost\n"); */
    }
    i++;
  }  
  
  err = FSClose(myRefNum);  
  if(err != noErr) {
    printf("Cannot close preference file %s (%d)\n", C_PREFERENCE_FILE, err);
  }

  return found;
}

int
GetTMExitStatus(Int32 node)
{
   return TMInfo[node].Exit_Status;
}

Boolean 
TMQuit(void)
{
    return FreeSharedHostMemory(_HostCall_commvar);
}

Boolean
AllocateSharedHostMemory (int nbytes, void** pp_lin_mem, unsigned long* pl_ph_mem)
{
 	int i;
	OSStatus err = 0;
    LogicalAddress logical_mapping[2];
    PhysicalAddress physical_mapping[2];
    IOPreparationTable IOTable;

	*pp_lin_mem = NULL;
	*pl_ph_mem  = NULL;

	*pp_lin_mem =  (void *)MemAllocatePhysicallyContiguous(nbytes,true);
	
	if (!*pp_lin_mem)
	{
      printf("AllocateSharedHostMemory: MemAllocatePhysicallyContiguous failed\n");
	  return false;
	}
	
	IOTable.options = (kIOMinimalLogicalMapping | kIOLogicalRanges | kIOIsInput);
	IOTable.state = 0;
	IOTable.addressSpace = kCurrentAddressSpaceID;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
自拍视频在线观看一区二区| 久久久99免费| 不卡在线视频中文字幕| 极品少妇xxxx偷拍精品少妇| 日韩电影一区二区三区四区| 亚洲韩国一区二区三区| 亚洲资源在线观看| 亚洲国产va精品久久久不卡综合| 亚洲午夜羞羞片| 午夜久久久久久久久| 天天免费综合色| 免费观看91视频大全| 久久精品国产亚洲高清剧情介绍 | 成人在线一区二区三区| 国产成人精品一区二| 成人爱爱电影网址| 欧美色图12p| 精品久久久久久久一区二区蜜臀| 欧美一卡二卡三卡四卡| 国产丝袜在线精品| 亚洲欧洲综合另类在线| 香蕉久久一区二区不卡无毒影院| 美女视频一区在线观看| 国产精品1区2区| 色女孩综合影院| 日韩精品最新网址| 1024精品合集| 激情综合亚洲精品| 成人av动漫在线| 欧美精品xxxxbbbb| 国产精品色婷婷久久58| 亚洲成av人影院在线观看网| 国产精品99久久久久| 91久久精品一区二区三区| 日韩欧美aaaaaa| 亚洲乱码中文字幕| 激情综合五月天| 日本精品一区二区三区高清| 欧美一区二区在线观看| 综合在线观看色| 蜜桃一区二区三区四区| 91年精品国产| 精品国产一区二区三区久久久蜜月| 国产精品传媒入口麻豆| 日日骚欧美日韩| 91浏览器入口在线观看| 26uuu欧美日本| 亚洲1区2区3区视频| 99精品偷自拍| 国产亚洲短视频| 日韩成人免费看| 一本一道久久a久久精品综合蜜臀| 欧美tk—视频vk| 性感美女久久精品| 色综合天天综合色综合av| 欧美精品一区二区三区在线播放| 亚洲综合成人网| 色婷婷综合久久久中文一区二区| 久久久久久综合| 久久精品国产色蜜蜜麻豆| 欧美日韩黄色一区二区| 亚洲欧美电影院| 成人黄色av网站在线| 久久九九久精品国产免费直播| 免费欧美高清视频| 91.com在线观看| 五月综合激情网| 91久久人澡人人添人人爽欧美 | 亚洲欧美电影一区二区| 成人黄色电影在线| 国产精品久久久久久久久免费丝袜| 麻豆成人久久精品二区三区红| 欧美精品 国产精品| 亚洲午夜电影在线| 欧美人伦禁忌dvd放荡欲情| 亚洲午夜电影网| 欧美欧美欧美欧美首页| 天天av天天翘天天综合网 | 国产精品资源在线观看| 久久在线观看免费| 国产一区免费电影| 国产欧美一区二区三区在线老狼 | 亚洲天堂2016| 99精品一区二区| 一区二区三区国产精品| 欧美视频一区二区三区四区| 亚洲国产sm捆绑调教视频| 91麻豆精品国产自产在线| 日本美女视频一区二区| 欧美变态口味重另类| 国产毛片精品视频| 国产精品久久久久aaaa樱花| 色综合久久久久久久久| 丝袜美腿亚洲一区| 日韩精品影音先锋| 成人在线综合网| 一区二区三区精品久久久| 欧美日本一区二区三区四区| 久久国内精品视频| 中文子幕无线码一区tr| 欧洲色大大久久| 六月丁香婷婷色狠狠久久| 国产日韩欧美精品一区| 色一情一伦一子一伦一区| 日韩av在线发布| 亚洲国产精品传媒在线观看| 色久综合一二码| 日本va欧美va瓶| 中文字幕精品三区| 678五月天丁香亚洲综合网| 国产精品88888| 亚洲成人综合网站| 久久久影视传媒| 日本韩国欧美一区二区三区| 蜜臀精品久久久久久蜜臀| 国产精品久久久久久久久免费相片 | 777奇米成人网| 成人国产免费视频| 男男成人高潮片免费网站| 亚洲欧洲成人自拍| 久久综合网色—综合色88| 在线观看成人小视频| 成人在线视频一区| 青青草国产精品97视觉盛宴 | 亚洲在线中文字幕| 国产女人aaa级久久久级| 91精品国产综合久久久久久| 成人免费高清在线| 人人超碰91尤物精品国产| 中文av一区二区| 精品国产青草久久久久福利| 欧美色图12p| 99久久久国产精品| 国产白丝精品91爽爽久久 | 一区精品在线播放| 久久久久国产精品厨房| 日韩一区二区三区高清免费看看| 91福利资源站| 99re成人在线| 丁香五精品蜜臀久久久久99网站| 久久成人18免费观看| 天堂蜜桃一区二区三区| 亚洲精品免费在线播放| 国产精品色一区二区三区| 亚洲国产精品99久久久久久久久| 精品久久久久久综合日本欧美 | 久久久精品国产免大香伊 | 丁香桃色午夜亚洲一区二区三区| 日本vs亚洲vs韩国一区三区二区 | 日韩精品国产精品| 调教+趴+乳夹+国产+精品| 亚洲一区二区高清| 亚洲午夜免费电影| 亚洲成精国产精品女| 亚洲国产欧美另类丝袜| 午夜在线电影亚洲一区| 午夜精品福利一区二区蜜股av| 亚洲最新视频在线观看| 亚洲一区电影777| 亚洲国产精品嫩草影院| 午夜久久福利影院| 蜜桃精品视频在线| 国产精品中文字幕日韩精品| 国产精品自拍在线| 91在线丨porny丨国产| 在线观看亚洲精品视频| 欧美日韩精品欧美日韩精品| 在线综合视频播放| 久久久久国产精品厨房| 国产精品美女久久久久久| 一区二区三区免费| 美日韩一级片在线观看| 国产成人免费av在线| av男人天堂一区| 欧美图片一区二区三区| 91精品婷婷国产综合久久性色| 精品精品国产高清a毛片牛牛| 久久精品亚洲精品国产欧美| 亚洲日本va午夜在线影院| 亚洲v中文字幕| 国产美女一区二区三区| 色综合天天综合| 欧美一区二区大片| 国产精品久久久久久久久果冻传媒 | 不卡影院免费观看| 欧美三级一区二区| 久久精品欧美一区二区三区麻豆| 成人欧美一区二区三区在线播放| 亚洲一区在线观看视频| 国产一区二区三区四区五区入口 | 91视视频在线观看入口直接观看www | 亚洲第一搞黄网站| 国模大尺度一区二区三区| a美女胸又www黄视频久久| 欧美男女性生活在线直播观看| 久久久国产午夜精品| 午夜精品久久久久久久久久久| 国产九九视频一区二区三区| 欧美日韩情趣电影| 国产精品久久久久久久久久免费看|