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

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

?? tm1stuff.c

?? PNX系列設備驅動 PNX系列設備驅動
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
 *  +-------------------------------------------------------------------+
 *  | Copyright (c) 1995-1998 by Philips Semiconductors.                |
 *  |                                                                   |
 *  | This software  is furnished under a license  and may only be used |
 *  | and copied in accordance with the terms  and conditions of such a |
 *  | license  and with  the inclusion of this  copyright notice.  This |
 *  | software or any other copies of this software may not be provided |
 *  | or otherwise  made available  to any other person.  The ownership |
 *  | and title of this software is not transferred.                    |
 *  |                                                                   |
 *  | The information  in this software  is subject  to change  without |
 *  | any  prior notice  and should not be construed as a commitment by |
 *  | Philips Semiconductors.                                           |
 *  |                                                                   |
 *  | This  code  and  information  is  provided  "as is"  without  any |
 *  | warranty of any kind,  either expressed or implied, including but |
 *  | not limited  to the implied warranties  of merchantability and/or |
 *  | fitness for any particular purpose.                               |
 *  +-------------------------------------------------------------------+
 *
 *
 *  Module name              : TM1stuff.c    1.34
 *
 *  Last update              : 11:02:48 - 98/07/10
 *
 *  Description              : 
 *
 *		This module provides functions to download and run executables on
 *      a TM-1000 with a Mac as host
 *
 *  Revision                 :
 */

/*-----------------------------includes-------------------------------------*/

#include <stat.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>

#include <Files.h>
#include <Folders.h>
#include <Script.h>
#include <PCI.h>
#include <DriverServices.h>
#include <Types.h>
#include <NameRegistry.h>

#include "TMDownLoader.h"
#include "mmio.h"
#include "TM1stuff.h"
#include "tmtypes.h"
#include "OpenDll.h"
#include "TM1IF.h"
#include "TMDownLoader.h"

/*-----------------------------defines---------------------------------------*/

/* name of the preference file */
#define C_PREFERENCE_FILE "TriMedia Preferences"
#ifdef _MPW
#define NL "\n"
#else 
#define NL "\r"
#endif

#define PREFERENCES "frequency=100000000" NL \
                    "dllpath=" NL \
                    "board=pci1131,1" NL
#define P_PREFERENCE_FILE "\p" C_PREFERENCE_FILE

/* number of entries in table with shared memory pointers */
#define SH_MEM_SLOTS 16

#define SET_RST_MASK		0x00000800
#define CLEAR_RST_MASK		0x00000400

#define	NUM_OF_SERVERS		1

/*	PCI Configuration register offsets */

#define CONFIG_COMMAND			0x04
#define CONFIG_STATUS			0x06
#define CONFIG_LATENCY			0x0D
#define CONFIG_BASE0_ADDRESS	0x10
#define CONFIG_BASE1_ADDRESS	0x14
#define MAX_STDIN_LINE_LENGTH 	1024


/*-------------------------------types----------------------------------------*/

/* table with shared memory pointers */
typedef struct IdPtr {
    IOPreparationID id;
    void* ptr;
} IdPtr;


TriMediaInfo	TMInfo[MAX_TM];			/* Info block for each TriMedia. */
UInt			TM_frequency;
int				NumberOfTMs = 0;		/* Total TriMedia's found in system. */
int				nodesLoaded;			/* Number of TriMedia nodes loaded with code. */

volatile UInt32 *_MMIO_bases[MAX_TM];

/*-----------------------------GLOBALS----------------------------------------*/

/* location of the communication buffer, so far 2 4-byte pointers */
extern volatile Address *_HostCall_commvar;

char			stdin_file[FILENAME_MAX];	/* stdin file. Console if empty. */
char			stdout_file[FILENAME_MAX];	/* stdout file. Console if empty. */
char			stderr_file[FILENAME_MAX];	/* stderr file. Console if empty. */
int				stdin_fd = STDIN_HANDLE;
int				stdout_fd = STDOUT_HANDLE;
int				stderr_fd = STDERR_HANDLE;

/*-----------------------------globals-this-file------------------------------*/

/* _HostCall_commvar location as seen from the target (when VM is on) */
static unsigned long        HostCall_commvar_target;

static IdPtr   ShMemList[SH_MEM_SLOTS] = { 0 };

static Bool    CommBufferClean = False;		
static Endian  object_endian;

/*------------------------------local-prototypes------------------------------*/

void      InitEmber(RegEntryID theEntryID);
OSStatus  GetBaseAddress( RegEntryID *pRegID, UInt32 *pBaseRegAddress, UInt8 offsetValue, UInt32 *pSpaceAllocated );
OSStatus  GetDeviceProperty( RegEntryID *pRegID, RegPropertyName *pPropertyName, RegPropertyValue *pPropertyValue, RegPropertyValueSize *pPropertySize );
OSStatus  DisposeProperty( RegPropertyValue propertyValue );
OSStatus  FindPropertyWithValue(const RegPropertyName *propertyName, const void *propertyValue, 
                               const RegPropertyValueSize propertySize, RegEntryID *foundEntry);

/*------------------------------functions-------------------------------------*/


Boolean TMRunning(void) 
{
	int		i;
	
	for (i = 0; i < nodesLoaded; i++)
	{
		if (TMInfo[i].TM_running)
			return true;
	}
			
	return false;
}

//===================================================================
//===================================================================
Boolean ResetTM(Int32 node)
{

    // clear and mask interrupts
    MMIO_M(node,IMASK)   = 0;
    MMIO_M(node,ICLEAR)  = 0xffffffff;

    // Ensure that BIU_CTL shows that CPU is now in reset
    // Writing a 0 to CR bit is a nop
    MMIO_M(node,BIU_CTL) &= ~CLEAR_RST_MASK;
    	
    // reset BIU
    MMIO_M(node,BIU_CTL) |= SET_RST_MASK;
    MMIO_M(node,BIU_CTL) &= ~SET_RST_MASK;
    
    // reset the peripherals
    MMIO_M(node,AO_CTL)      = 0x80000000;
    MMIO_M(node,AO_FREQ)     = 0x0;
    MMIO_M(node,AI_CTL)      = 0x80000000;
    MMIO_M(node,AI_FREQ)     = 0x0;
    MMIO_M(node,VI_CTL)      = 0x00080000;
    MMIO_M(node,VI_CLOCK)    = 0x0;
    MMIO_M(node,VO_CTL)      = 0x80000000;
    MMIO_M(node,VO_CLOCK)    = 0x0;
    MMIO_M(node,SSI_CTL)     = 0xc0000000;
    // Roy does the following 10 times...oh, boy
    MMIO_M(node,ICP_SR)      = 0x80;
    MMIO_M(node,IIC_CTL)     = 0;
    MMIO_M(node,VLD_COMMAND) = 0x00000401;

    // reset JTAG
    MMIO_M(node,JTAG_DATA_IN)     = 0;
    MMIO_M(node,JTAG_DATA_OUT)    = 0;
    MMIO_M(node,JTAG_CTL)         = 0x4;

    // reset breakpoints, I$ lock and ??
    MMIO_M(node,BICTL)       = 0;
    MMIO_M(node,IC_LOCK_CTL) = 0;
    MMIO_M(node,ARB_BW_CTL)  = 0;
    MMIO_M(node,ARB_RAISE)   = 0;
    
    // reset timers
    MMIO_M(node,TIMER1_TCTL) = 0xfffffffe;
    MMIO_M(node,TIMER2_TCTL) = 0xfffffffe;
    MMIO_M(node,TIMER3_TCTL) = 0xfffffffe;
    MMIO_M(node,SYSTIMER_TCTL) = 0xfffffffe;
    
    CommBufferClean = False;

    return true;
}


//===================================================================
//===================================================================
//

Boolean
InitTM( Boolean reinitialize , Int32 node)
{
	OSErr		theErr;
	UInt16		data16;
	UInt32		addr;
	int			i;
	OSStatus	osErr;
	RegEntryID  *pNodeID;
	
	pNodeID = &TMInfo[node].NodeID;
	
	if ( reinitialize ) {
		osErr = ExpMgrConfigWriteByte(pNodeID, (LogicalAddress) (CONFIG_LATENCY), TMInfo[node].ConfigHeader[CONFIG_LATENCY]);
		if (osErr != noErr) {
			printf("** Error: Could not write to PCI configuration\n");
			return false;
		}
		for ( i = 0; i < 8; i++ ) {
	      osErr = ExpMgrConfigWriteByte(pNodeID, (LogicalAddress) (CONFIG_BASE0_ADDRESS + i), TMInfo[node].ConfigHeader[CONFIG_BASE0_ADDRESS + i]);
		  if (osErr != noErr) {
			printf("** Error: Could not write to PCI configuration\n");
			return false;
		  }
		}
		osErr = ExpMgrConfigWriteByte(pNodeID, (LogicalAddress) (CONFIG_COMMAND), 0x04);
		if (osErr != noErr) {
			printf("** Error: Could not write to PCI configuration\n");
			return false;
		}
	}
	
	// first thing to do is to make sure that memory access is enabled
		// this is the PCI command register
	addr = CONFIG_COMMAND;
	theErr = ExpMgrConfigReadWord(pNodeID, (LogicalAddress)addr, &data16);
	if (theErr != noErr) {
		printf("** Error: Could not read from PCI configuration (1)\n");
		return false;
	}
		// set the memory space access enable
	data16 |= 1<<1;		
	theErr = ExpMgrConfigWriteWord(pNodeID, (LogicalAddress)addr, (UInt16)data16);
	if (theErr != noErr) {
		printf("** Error: Could not write to PCI configuration\n");
		return false;
	}
	
    MMIO_M(node,BIU_CTL)      = 0x00000202;
	MMIO_M(node,MMIO_BASE)    =  TMInfo[node].mmio_base;
	MMIO_M(node,DRAM_BASE)    =  TMInfo[node].sdram_base;
	MMIO_M(node,DRAM_LIMIT)   =  TMInfo[node].sdram_base + TMInfo[node].sdram_size;

	// TMInfo[node].frequency = TM_frequency; ???
	TMInfo[node].TM_running = false;

	i = 0;
	osErr = noErr;
	while ((osErr == noErr) & (i < 64)) 
	{
		osErr = ExpMgrConfigReadByte(pNodeID, (LogicalAddress) i, &TMInfo[node].ConfigHeader[i]);
		i++;
	}

	if (osErr != noErr) 
	{
		printf("** Error: Could not read from PCI configuration (2)\n");
		return false;
	}
	else
		return true;
}


//===================================================================


static int exitf(UInt32 node_id, Int32 status) 
{
    TMInfo[node_id].Exit_Status = status;
    TMInfo[node_id].TM_running = false;

    if (!TMRunning())
    	TM1IF_term();
    	
    return 0; 
}


static int my_fstat( int fildes, struct stat *buf )
{
    if (  fildes == STDIN_HANDLE
       || fildes == STDOUT_HANDLE 
       || fildes == STDERR_HANDLE
       ) 
    {
		// for some strange reason, MW's fstat doesn't handle
		// stdin, stdout & stderr, so we have to fill it out 
		// explicitly
		buf->st_dev 	= 0;
		buf->st_ino 	= fildes;
		buf->st_mode 	= 0020000;
		buf->st_nlink 	= 1;
		buf->st_uid 	= getuid();
		buf->st_gid 	= getgid();
		buf->st_rdev 	= 0;
		buf->st_size 	= 4096;
		buf->st_atime 	= time(0L);
		buf->st_mtime 	= time(0L);
		buf->st_ctime 	= time(0L);
		buf->st_blksize = 4096;
		buf->st_blocks 	= 1;
        return 0;
    } else {
        int result= fstat(fildes,buf);
        buf->st_mode <<=4;
        return result;
    }
}

static int my_stat( char *name, struct stat *buf );

static int my_stat( char *name, struct stat *buf )
{
    int result;
    
    if (name == NULL)
        return -1;
    result = stat(name,buf);
    buf->st_mode <<=4;
    return result;
}


static int my_read( int fd, char* buf, int n );

static int my_read( int fd, char* buf, int n )
{
    int result;
    static char line[MAX_STDIN_LINE_LENGTH];
    static char *linep = NULL;

	if (fd == STDIN_HANDLE && stdin_fd != STDIN_HANDLE)
		fd = stdin_fd;

    if ( fd == STDIN_HANDLE ) {
        int i;
        for (i=0; i<n; i++) {
	    if (linep == NULL) {
		char * check;
		check = fgets(line, MAX_STDIN_LINE_LENGTH-1, stdin);
		if (check == NULL) {
		    linep = NULL;
		    return 0;
		}
		linep = line;
	    }
	    if (*linep == '\n') {
		buf[i] = *linep;
		linep = NULL;
		return i+1;
	    } else {
		buf[i] = *linep++;
	    }
        }
        return n;
    } else {
        result= read(fd,buf,n);
    }

    return result;
}

static int my_write( int fd, char* buf, int n );

static int my_write( int fd, char* buf, int n )
{
	if (fd == STDOUT_HANDLE && stdout_fd != STDOUT_HANDLE)
		fd = stdout_fd;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人欧美一区二区三区在线播放| 国产精品一级在线| 国产综合色视频| 欧美日韩高清一区| 国产精品久久久久久久久久免费看| 婷婷中文字幕一区三区| av在线不卡网| 国产精品久久久久婷婷| 精品一区二区三区在线播放视频 | 国产欧美日韩久久| 日韩黄色免费电影| 欧美日韩一区久久| 亚洲综合在线电影| 91丨porny丨蝌蚪视频| 国产喷白浆一区二区三区| 久久成人综合网| 日韩一区二区在线看片| 五月婷婷激情综合网| 色av成人天堂桃色av| 国产精品视频看| 成人自拍视频在线| 久久午夜色播影院免费高清 | 亚洲成人精品在线观看| 一本大道久久a久久综合婷婷| 国产视频一区二区在线| 激情深爱一区二区| 久久久精品中文字幕麻豆发布| 久久国产成人午夜av影院| 日韩欧美一二三| 激情文学综合插| 国产亚洲视频系列| 成人av中文字幕| 亚洲视频免费在线观看| 在线精品视频免费播放| 亚洲成a天堂v人片| 日韩三级.com| 国产成人亚洲综合色影视| 国产精品青草综合久久久久99| youjizz国产精品| 一区二区三区在线视频观看| 欧美日韩一卡二卡三卡| 蜜臀国产一区二区三区在线播放| 精品少妇一区二区三区免费观看| 国产自产v一区二区三区c| 欧美国产欧美综合| 在线一区二区三区四区五区| 亚洲r级在线视频| 精品久久久久久久一区二区蜜臀| 国产乱码精品一区二区三| 国产精品区一区二区三| 欧美日韩在线三级| 久久99国产精品尤物| 欧美激情在线观看视频免费| 91福利资源站| 久久不见久久见免费视频1| 日本一区二区久久| 欧美视频在线观看一区二区| 日本成人在线网站| 中文字幕的久久| 欧美区视频在线观看| 国产电影一区在线| 亚洲va欧美va人人爽午夜| 久久久久久亚洲综合| 欧美性感一类影片在线播放| 久久er精品视频| 亚洲精品成人在线| 久久久久9999亚洲精品| 欧美视频日韩视频| 国产麻豆精品久久一二三| 亚洲精品视频一区| 久久影院视频免费| 欧美视频自拍偷拍| thepron国产精品| 久久99精品视频| 一区二区三区四区乱视频| wwwwww.欧美系列| 色哟哟国产精品免费观看| 国产在线乱码一区二区三区| 亚洲综合一区在线| 国产精品久久久久久福利一牛影视| 9191精品国产综合久久久久久 | 国产一区二区影院| 亚洲福利一区二区三区| 国产精品免费观看视频| 日韩免费在线观看| 欧美日韩精品久久久| 不卡一区二区三区四区| 韩国一区二区在线观看| 日本亚洲免费观看| 亚洲一区二区三区四区不卡| 亚洲欧美在线观看| 欧美激情一区二区在线| xfplay精品久久| 日韩视频永久免费| 欧美人牲a欧美精品| 在线一区二区三区四区| 91麻豆精东视频| www.66久久| 不卡的av电影| thepron国产精品| 成人高清免费观看| 国产成人高清视频| 国产激情视频一区二区三区欧美 | 亚洲欧美日韩中文播放| 国产精品美女久久久久久久网站| 亚洲精品一区二区三区蜜桃下载| 91精品国产一区二区三区蜜臀| 欧美日韩在线播放一区| 91国模大尺度私拍在线视频| 91黄色激情网站| 欧洲精品一区二区三区在线观看| 色天使色偷偷av一区二区| av电影天堂一区二区在线| 99久久精品免费| av高清不卡在线| 在线免费观看成人短视频| 欧美三级三级三级爽爽爽| 欧美日韩成人一区二区| 欧美精品久久一区二区三区| 7777精品伊人久久久大香线蕉超级流畅| 欧美三级中文字幕在线观看| 欧美疯狂性受xxxxx喷水图片| 欧美精品aⅴ在线视频| 日韩情涩欧美日韩视频| 国产亚洲一区二区三区| 国产精品看片你懂得| 亚洲激情一二三区| 日韩成人一区二区三区在线观看| 免费成人性网站| 国产91丝袜在线观看| 92国产精品观看| 欧美绝品在线观看成人午夜影视| 日韩一区二区不卡| 中文字幕不卡的av| 亚洲已满18点击进入久久| 日本欧美在线看| 懂色av中文一区二区三区| 一本色道**综合亚洲精品蜜桃冫| 欧美日韩国产电影| 久久久不卡影院| 一区二区三区美女| 蜜桃视频在线观看一区| aa级大片欧美| 91精品国产综合久久香蕉的特点| 国产拍欧美日韩视频二区| 亚洲综合一二区| 国产黄色精品视频| 欧美综合天天夜夜久久| 欧美精品一区二区高清在线观看| 国产精品久久久久久久岛一牛影视| 亚洲午夜av在线| 国产 欧美在线| 91精品国产免费| 中文字幕在线观看不卡| 久久精品国产999大香线蕉| av欧美精品.com| 欧美大黄免费观看| 亚洲男人的天堂在线观看| 精品一区二区三区av| 欧美性视频一区二区三区| 欧美激情中文不卡| 久久国产精品色婷婷| 欧美无人高清视频在线观看| 欧美激情资源网| 久久99精品久久久久久国产越南| 欧美亚一区二区| 中文字幕综合网| 国产成人三级在线观看| 欧美日本乱大交xxxxx| 亚洲免费色视频| 成人av在线一区二区| 久久久久久免费| 免费av成人在线| 欧美日韩www| 亚洲一级二级在线| 91在线观看视频| 国产亚洲自拍一区| 国内成人精品2018免费看| 欧美高清一级片在线| 亚洲精品乱码久久久久| 99久久精品免费看国产| 国产精品午夜免费| 国产精品亚洲第一区在线暖暖韩国| 7777女厕盗摄久久久| 午夜亚洲福利老司机| 在线一区二区三区四区五区 | 欧美日韩一二区| 亚洲精品国产品国语在线app| 风间由美性色一区二区三区| 精品国产电影一区二区| 狠狠色综合色综合网络| 日韩美女在线视频| 久久成人免费网| 亚洲精品一区二区三区四区高清 | 欧美日韩视频一区二区| 一区二区三区中文字幕| 欧美自拍偷拍一区| 亚洲v日本v欧美v久久精品| 欧美军同video69gay| 免费高清视频精品|