2020生產實習——信諾達的

2020-09-21 17:00:42

!未經允許,不可經任何途徑轉發和參照。與此同時人腦編譯,有錯誤概不負責。但歡迎找我討論
不說廢話直入主題
(注意,請仔細閱讀,因為程式碼非完整程式碼,缺少相應的功能測試,和遍歷測試)

常用函數使用

首先要理解一些函數使用
SET_DPS我的理解是設定電源電壓,引數如下
在這裡插入圖片描述
PMU我的理解是給管腳加激勵,同時判斷條件符不符合
CONDITIONS是設定激勵型別和大小

在這裡插入圖片描述
在這裡插入圖片描述

PMU_MEASURE是測量的過程,需要設定測量通道,測量範圍,返回符不符合範圍,常配合RUN_PATTEN使用
在這裡插入圖片描述

在這裡插入圖片描述

RUN_PATTERN執行圖形檔案,常常只有和START_INDEX()對應的引數有用
在這裡插入圖片描述
SET_INPUT_LEVEL();我的理解是設定圖形PATTEN輸入的高低大小電平
SET_OUTPUT_LEVEL();我的理解是設定圖形輸出高低的範圍來決定輸出是否正確
在這裡插入圖片描述
DPS_MEASURE()和PMU類似,不同的是DPS測量的是電源引腳的電流資料
在這裡插入圖片描述
在這裡插入圖片描述
在這裡插入圖片描述

測試程式編寫

這裡的MEASURE通道需要和圖形對應

//連結性測試
//45-47 SDA SCL WP 
// 圖形0用於功能,(3用於Voh,GG) 2用於Vol 4用於ICC read 5用於ICC WIRTE 6用於輸入全0, 7用於輸入全1
	SET_DPS(1,0,V,20,MA);
	PMU_CONDITIONS(FIMV,-0.1,MA,5,V);
	if(!PMU_MEASURE("1-3,45-47",15,"CON",V,-0.1,-4.9))//隨便寫的原理應該是測量反偏電流
		BIN(1);

在這裡插入圖片描述
在這裡插入圖片描述
通過調整電源電壓測量VCC範圍,調整INPUT_LEVEL看Vil(最高)和Vih(最低)我覺得選最高最低就夠了

//功能測試


	SET_DPS(1,2.4,V,16,MA);
	SET_DPS(2,2.4,V,16,MA);
	SET_INPUT_LEVEL(1.68,0.72);
	SET_OUTPUT_LEVEL(1.68,0.4);
	SET_PERIOD(2000);
	SET_TIMING(100,700,1500);
	FORMAT(NRZ,"1-3,45-47");     //這話應該沒啥用  
	if(!RUN_PATTERN("FUN_MIN",0,1,0,0))
		BIN(2);

	SET_DPS(1,5.5,V,40,MA);
	SET_DPS(2,5.5,V,40,MA);
	SET_INPUT_LEVEL(3.85,1.65);
	SET_OUTPUT_LEVEL(3.85,0.4);
	if(!RUN_PATTERN("FUN_MAX",0,1,0,0))
		BIN(2);


	SET_DPS(1,5,V,40,MA);
	SET_DPS(2,5,V,40,MA);
	SET_INPUT_LEVEL(3.5,1.5);
	SET_OUTPUT_LEVEL(3.5,0.4);
	FORMAT(NRZ0,"1-3,45-47");       
	if(!RUN_PATTERN("FUN",0,1,0,0))
		BIN(2);

在這裡插入圖片描述
看到VOL測試是在2.4V電源電壓,輸出負載電流2.1mA下,最大為0.4V
先不考慮圖形檔案,當做最後會讓輸出一個低電平

// VOL 測試
	SET_DPS(1,2.4,V,50,MA);
	SET_DPS(2,2.4,V,50,MA);
	SET_INPUT_LEVEL(2.4,0.1);
	RUN_PATTERN(2,1,0,0);
	PMU_CONDITIONS(FIMV,2.1,MA,2.4,V);//手冊寫明測試情況
	if(!PMU_MEASURE("45",15,"VOL",V,0.4,No_LoLimit))//45腳SDA
		BIN(5);

在這裡插入圖片描述

ICC測試中需要保持時脈頻率在100kHZ,我大概根據程式碼結構估算了時鐘週期在3333ns,其他和上面差不多,只是測量電源工作電流而已

// ICC1 測試
	SET_DPS(1,5,V,50,MA);
	SET_DPS(2,5,V,50,MA);
    SET_INPUT_LEVEL(5,0);
    SET_PERIOD(3333);
    SET_TIMING(100,500,1000);
    RUN_PATTERN(4,1,0,0);
	if(!DPS_MEASURE(1,R20MA,15,"ICC1",MA,2,No_LoLimit))
        BIN(6);
    

// ICC2 測試
    SET_DPS(1,5,V,50,MA);
	SET_DPS(2,5,V,50,MA);
    SET_INPUT_LEVEL(5,0);
    SET_PERIOD(3333);
    SET_TIMING(100,500,1000);
    RUN_PATTERN(5,1,0,0);
	if(!DPS_MEASURE(1,R20MA,15,"ICC2",MA,5,No_LoLimit))
        BIN(7);

在這裡插入圖片描述
輸入洩露電流,為輸入管腳固定輸入後輸入電流的大小,程式碼基本差不多,我感覺甚至不用PATTEN直接加壓測流。但考慮到有兩個情況分別是1和0,所以測兩遍。

// ILI 測試 所有輸入都等於0 所有輸入都等於VCC
    SET_DPS(1,5,V,2,MA);
	SET_DPS(2,5,V,2,MA);
    SET_INPUT_LEVEL(5,0);
//	SET_OUTPUT_LEVEL(3.5,1.5);
    PMU_CONDITIONS(FIMV,5,V,1,UA);
 	if(!PMU_MEASURE("1-3,45-47",15,"ILI1",UA,1,No_LoLimit))
		BIN(8);   
    //所有輸入為0
    PMU_CONDITIONS(FIMV,0,V,1,UA);
 	if(!PMU_MEASURE("1-3,45-47",15,"ILI2",UA,1,No_LoLimit))
		BIN(8);  

在這裡插入圖片描述
因為Vout只能在Vout=0的時候所以只有一種情況,執行Vol的情況圖形

// ILO 測試
    // RUN_PATTERN(3,1,0,0);
    // PMU_CONDITIONS(FIMV,5,V,1,UA);
    // if(!PMU_MEASURE("45",15,"ILO1",UA,1,No_LoLimit))
    //     BIN(9);
    RUN_PATTERN(2,1,0,0);   
    PMU_CONDITIONS(FIMV,0,V,1,UA); 
    if(!PMU_MEASURE("45",15,"ILO2",UA,1,No_LoLimit))
        BIN(9);  

在這裡插入圖片描述
穩態電流測的是穩態時電源電流,所以程式碼如下:

// ISTB1 測試
    SET_DPS(1,5,V,2,MA);
	SET_DPS(2,5,V,2,MA);
    SET_INPUT_LEVEL(5,0);
    RUN_PATTERN(6,1,0,0);//全零
 	if(!DPS_MEASURE(1,R20UA,15,"ISTB11",UA,5,No_LoLimit))
        BIN(10);

    RUN_PATTERN(7,1,0,0);//全一
 	if(!DPS_MEASURE(1,R20UA,15,"ISTB12",UA,5,No_LoLimit))
        BIN(10);    
// ISTB2 測試
    SET_DPS(1,2.4,V,2,MA);
	SET_DPS(2,2.4,V,2,MA);
    SET_INPUT_LEVEL(2.4,0);
    RUN_PATTERN(6,1,0,0);//全零
 	if(!DPS_MEASURE(1,R20UA,15,"ISTB21",UA,4,No_LoLimit))
        BIN(11);
    RUN_PATTERN(7,1,0,0);//全一
 	if(!DPS_MEASURE(1,R20UA,15,"ISTB22",UA,4,No_LoLimit))
        BIN(11);    

圖形檔案編寫

圖形0用於功能,(3用於Voh,GG) 2用於Vol 4用於ICC read 5用於ICC WIRTE 6用於輸入全0, 7用於輸入全1

首先圖形0,為功能測試服務,主要利用IIC讀寫測試每個單元儲存模組、地址控制、WP是否好用等。我只演示IIC讀寫測試中的一部分,其他的請自行編寫。

解析IIC讀寫協定

開始訊號
在這裡插入圖片描述
在SCL高電平時,SDA從0變1

    INC     (000 110)
    INC     (000 010)
    INC     (000 000)//開始

結束訊號

在這裡插入圖片描述
在SCL高電平時,SDA從底變高

    INC     (000 010)
    INC     (000 110)//結束標誌
    INC     (000 100)//可以算作結束,實際用於遏制匯流排

傳送
在這裡插入圖片描述
SDA需要在SCL從底到高到底時保持穩定

    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//資料第一位,注意放的是資料高位

主機接受應答
主機釋放SDA,變為接收SDA,SCL從底變高,判斷SDA情況,如果SDA底為應答,高為非應答
以下展示非應答

    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收

主機傳送應答
和傳送資料一樣,底為主機響應從機應答,高為主機響應從機非應答
舉例在主機接收資料時的非應答

    //主機傳送響應(即順序繼續接收),非響應(準備停止),此處非響應停止
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//

EEPROM具體程式

首先引腳定義,和測試程式對應

MEM_SOURCE_15;

PINDEF

A0    =I,BIN,(1)
A1    =I,BIN,(2)
A2    =I,BIN,(3)
SDA   =IO,BIN,(45)
SCL   =I,BIN,(46)
WP    =I,BIN,(47)


//測試依據:NS
//  負載電阻:10K(Pin 7-VCC,15-VCC)
//  負載電容:1000P(Pin 7-6,15-14)
//  在測試不同廠家的器件時,請根據規範適當改變測試周期與選通時間。

然後具體圖形0的編寫

MAIN_F

START_INDEX(0) //功能檢測,頁寫檢測0、1、並讀檢測,然後WP看保護,然後測試地址控制器(我這裡只寫了寫0000 0000為FF並讀0000 0000,其他自己補充)

範例為單獨寫一個地址,資料為FF
在這裡插入圖片描述
上面是寫邏輯的時序圖
為開始訊號->發資料1010 A2A1A0 0(裝置地址)->等待從機響應為低電平->發資料 寫資料地址->等待從機響應為低電平->停止訊號
看懂之前IIC模組,就知道只是個簡單拼接而已

//************************************************************************************************************************************//
    //演示的是裝置地址000,寫一位元組FF到資料地址0000 0000
    INC     (000 110)
    INC     (000 010)
    INC     (000 000)//開始
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第一位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第二位補0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第三位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第四位補0 
    //三位實際地址,以000為例
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A0
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址第八位 SDA位為0是寫為1是讀(IIC協定7位+1位)   以上是裝置地址
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//資料地址第一位,注意放的是地址高位
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//3
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//4
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//5
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//6
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//7
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//8,以上是資料地址以0000 0000為例
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    //寫資料8位元,先以全寫1
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//資料第一位,注意放的是資料高位
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//2
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//3
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//4
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//5
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//6
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//7
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//8,以上是資料
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 010)
    INC     (000 110)//結束標誌
    INC     (000 100)//可以算作結束,實際用於遏制匯流排

單獨讀一個地址為例
在這裡插入圖片描述
流程為:
開始訊號->發資料1010 A2A1A0 0(裝置地址)->等待從機響應為低電平->發資料 寫資料地址->等待從機響應為低電平->開始訊號->發資料1010 A2A1A0 0(裝置地址)->等待從機響應為低電平->浮空等待資料和主機接收從機應答程式碼差不多,迴圈8次->傳送非應答(準備停止,應答就繼續發)->停止訊號
程式碼一樣為拼裝

    //************************************************************************************************************************************//
    //讀裝置000的資料地址0000 0000的資料
    INC     (000 110)
    INC     (000 010)
    INC     (000 000)//開始
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第一位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第二位補0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第三位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第四位補0 
    //三位實際地址,以000為例
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A0
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址第八位 SDA位為0是寫為1是讀(IIC協定7位+1位)   以上是裝置地址
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//資料地址第一位,注意放的是地址高位
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//3
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//4
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//5
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//6
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//7
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//8,以上是資料地址以0000 0000為例
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 110)
    INC     (000 010)
    INC     (000 000)//開始
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第一位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第二位補0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第三位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第四位補0 
    //三位實際地址,以000為例
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址第八位 SDA位為0是寫為1是讀(IIC協定7位+1位)
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    //因為上一步吧0000 0000的全寫1了檢測的時候就是全H,接下來要接收8位元資料
    INC     (000 X00)
    INC     (000 H10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 H10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 H10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 H10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 H10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 H10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 H10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 H10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    //主機傳送響應(即順序繼續接收),非響應(準備停止),此處非響應停止
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//
    INC     (000 010)
    INC     (000 110)//結束標誌
    INC     (000 100)//可以算作結束,實際用於遏制匯流排

HALT     (000 100)

圖形2的編寫,因為根據測試檔案,圖形2測試的是Vol,所以只需SDA為從機傳送低電平即應答訊號即可

START_INDEX(2) //Vol測試,即讓SDA低電平,即讓EEPROM來個應答訊號即可
    INC     (000 110)
    INC     (000 010)
    INC     (000 000)//開始
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第一位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第二位補0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第三位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第四位補0 
    //三位實際地址,以000為例
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A0
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址第八位 SDA位為0是寫為1是讀(IIC協定7位+1位)   以上是裝置地址
    INC     (000 X00)
    INC     (000 L10)
HALT     (000 L10)

圖形4,是IIC迴圈讀程式,利用JMP和LDF使程式一直讀即可,參考讀程式碼程式,因不在乎結果所以用X代替H檢測高電平。

START_INDEX(4) //用於ICC read,反覆讀取
    //************************************************************************************************************************************//
    //讀裝置000的資料地址0000 0000的資料
    INC     (000 110)
    INC     (000 010)
    INC     (000 000)//開始
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第一位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第二位補0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第三位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第四位補0 
    //三位實際地址,以000為例
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A0
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址第八位 SDA位為0是寫為1是讀(IIC協定7位+1位)   以上是裝置地址
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//資料地址第一位,注意放的是地址高位
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//3
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//4
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//5
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//6
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//7
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//8,以上是資料地址以0000 0000為例
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 110)
    INC     (000 010)
    INC     (000 000)//開始
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第一位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第二位補0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第三位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第四位補0 
    //三位實際地址,以000為例
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址第八位 SDA位為0是寫為1是讀(IIC協定7位+1位)
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    //讀迴圈,因為檔案裡說了會形成迴圈_環,所以127+1=0所以讀就完事了,而且不在意高低電平,X代替H、L
    LDF     (000 X00)
    //因為上一步吧0000 0000的全寫1了檢測的時候就是全H,接下來要接收8位元資料
A   INC     (000 X00)
    INC     (000 X10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 X10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 X10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 X10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 X10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 X10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 X10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 X00)
    INC     (000 X10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    //主機傳送響應(即順序繼續接收),非響應(準備停止),此處響應繼續讀
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//
    JMP,A   (000 000)
HALT     (000 000)

圖形5,類似,IIC的連續寫

START_INDEX(5) //用於ICC write,反覆寫
//************************************************************************************************************************************//
    //演示的是裝置地址000,寫一位元組FF到資料地址0000 0000
    INC     (000 110)
    INC     (000 010)
    INC     (000 000)//開始
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第一位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第二位補0
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//補全8位元地址的第三位補1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址的第四位補0 
    //三位實際地址,以000為例
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A1
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//A0
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//補全8位元地址第八位 SDA位為0是寫為1是讀(IIC協定7位+1位)   以上是裝置地址
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//資料地址第一位,注意放的是地址高位
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//2
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//3
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//4
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//5
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//6
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//7
    INC     (000 000)
    INC     (000 010)
    INC     (000 000)//8,以上是資料地址以0000 0000為例
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    //寫回圈
    LDF     (000 010)
    //寫資料8位元,先以全寫1
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//資料第一位,注意放的是資料高位
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//2
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//3
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//4
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//5
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//6
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//7
    INC     (000 100)
    INC     (000 110)
    INC     (000 100)//8,以上是資料
    INC     (000 X00)
    INC     (000 L10)
    INC     (000 X00)//等待響應H,判斷是否為高L,其中0 1代表輸入,L H代表接收
    JMP,B   (000 X00)


HALT    (000 X00)

圖形6,全底,圖形7,全高

START_INDEX(6) //用於輸入全0
    INC     (000 000)
HALT    (000 000)

START_INDEX(6) //用於輸入全1
    INC     (111 111)
HALT    (111 111)