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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? buxx_adsc.c

?? bu1566dsp芯片用來處理ov7660或其他30萬攝像模組的圖像預(yù)覽.圖像拍照(jpeg壓縮)
?? C
?? 第 1 頁 / 共 5 頁
字號(hào):
/* ************************************************************************ */
/*                                                                          */
/* ROHM BU15xx demo firmware on MD2306                                      */
/*     Client   : ROHM Co., Ltd.丂丂丂丂丂丂                                 */
/*     End User :                                                           */
/*                                                                          */
/*     Processor: ARM-7TDMI(THUMB Mode)                                     */
/*     Dev.Env. : ARM-SDTv2.51                                              */
/*                                                                          */
/*     API:BU15xx control Routines                                          */
/*                                                                          */
/*     file     : BUxx_aDSC.c                                               */
/*     Auther   : J.SATO(NTC)丂                                             */
/*     Date     : 2004/Jul./1 	                                            */
/*                                                                          */
/*     Copyright (c) 2002-04 Naritagiken Co., Ltd. All rights reserved.     */
/* ************************************************************************ */

/* ************************************************** */
/*		     INCLUDE FILES		      */
/* ************************************************** */
#include "BUxx_aDSC.h"
#include "BUxx_demoset.h"
#include "LPC2294.h"

/* ************************************************** */
/*		        TYPEDEF		    	      */
/* ************************************************** */
#define  BU1554_MIN(x,y)   ((x)>(y) ? (y) : (x))

 /* ************************************************** */
/*		     LOCAL DEFINES		      */
/* ************************************************** */

/* ************************************************** */
/*		    GLOBAL VARIABLE		      */
/* ************************************************** */

volatile int gl_bank_chk;
volatile int gl_je_end_chk;
volatile int gl_jd_end_chk;
volatile int gl_cam_end_chk;
volatile int gl_check_int;
volatile int gl_dsc_status;

#ifdef HOSTJD_TEST        
unsigned char gl_intcheck_sequence[30];
unsigned char gl_intcheck_index=0;
unsigned char gl_intdisp_sequence[30];
unsigned char gl_intdisp_index=0;
unsigned char gl_intmask_begin=0;
unsigned char gl_intmask_end=0;
unsigned char gl_jpgintmask_begin=0;
unsigned char gl_jpgintmask_end=0;
#endif

//
// Structs and Types for JPEG header
//

typedef struct
{                               // Huffman table
    UINT8 cod[16];
    UINT8 val[1];
}
HTABLE;

typedef struct
{                               // Q table
    UINT8 table[8][8];
}
QTABLE;

typedef struct
{                               // header information
    UINT16 X;
    UINT16 Y;
    UINT16 interval;
    UINT8 type;                 // 0:444, 1:422, 2:411, 3:420, 4:gray
    HTABLE *h_y_dc;
    HTABLE *h_y_ac;
    HTABLE *h_c_dc;
    HTABLE *h_c_ac;
    QTABLE *q_y;
    QTABLE *q_c;
    UINT8 *code;
    UINT32 code_size;
}
JPEG_INFO;

UINT32 ctable[] = { 0, 8035, 7568, 6811, 5793, 4551, 3135, 1598 };
UINT8 zigzag[] = { 0, 1, 8, 16, 9, 2, 3, 10,
    17, 24, 32, 25, 18, 11, 4, 5,
    12, 19, 26, 33, 40, 48, 41, 34,
    27, 20, 13, 6, 7, 14, 21, 28,
    35, 42, 49, 56, 57, 50, 43, 36,
    29, 22, 15, 23, 30, 37, 44, 51,
    58, 59, 52, 45, 38, 31, 39, 46,
    53, 60, 61, 54, 47, 55, 62, 63
};


typedef struct
{
    UINT8 regread[2];
}
JPEG_data;

typedef struct
{
    UINT8 Lf[2];
    UINT8 P;
    UINT8 Y[2];
    UINT8 X[2];
    UINT8 Nf;
    UINT8 CHVT[3][3];           //CHVT[?][0]:C,CHVT[?][1]:HV,CHVT[?][2]:T       
}
SOF_data;

typedef struct
{
    UINT8 Lh[2];
    UINT8 TcTh;
    UINT8 Ln[16];
}
DHT_data;

typedef struct
{
    UINT8 Lq[2];
    UINT8 PqTq;
    UINT8 Qn[64];
}
DQT_data;

typedef struct
{
    UINT8 Lr[2];
    UINT8 Ri[2];
}
DRI_data;


typedef struct
{
    UINT8 Ls[2];
    UINT8 Ns;
    UINT8 CTT[4][2];            //CTT[?][0]:Cs,CTT[?][1]:TdTa   
}
SOS_data;

/* ************************************************** */
/*		         CONST			      */
/* ************************************************** */

/* ************************************************** */
/*		    GLOBAL FUNCTIONS		      */
/* ************************************************** */

/* ************************************************** */
/*		     LOCAL FUNCTIONS		      */
/* ************************************************** */
static int jpeg_encode(UINT16 * start_add, UINT32 * const jpeg_size,
                       const int entype, const UINT16 je_q,
                       const UINT16 hflip);
static int jpeg_decode(UINT8 * start_add, UINT32 * const jpeg_size,
                       const CAMSET * const cam);
static int jpeg_HostDec(UINT8 * start_add, UINT32 * const jpeg_size, UINT16* p_u16Rgb_addr,
                       const CAMSET * const cam);

static int analyze_header(UINT8 * const jpeg, UINT32 * const jpeg_size,
                          JPEG_INFO * const jpeg_info);
static void set_jpeg_setting(const UINT16 X, const UINT16 Y,
                             const UINT16 interval, const UINT8 type);
static void set_huf_table(const HTABLE * const y_dc,
                          const HTABLE * const y_ac,
                          const HTABLE * const c_dc,
                          const HTABLE * const c_ac);
static void set_q_table(const QTABLE * const q_y,
                        const QTABLE * const q_c);
static void set_each_q_table(const QTABLE * const qtbl);
static void set_code(UINT8 * code, const UINT32 start, const UINT32 end);
static void read_code(UINT16 ** start_add, int store_num);
static void CheckJpegInt(void);
static int JpegIntDisp(UINT16* u16Rgb_addr, UINT32* p_u32CurRgbSize, UINT32 u32TotalRgbSize);

//-----------------------------------------------------------------------------
//                             bu15xx initialize
//-----------------------------------------------------------------------------
int aDSC_bu15xx_OPEN(void)
{
    int i;
    UINT16 temp;
    int ret_code = 0;
    int err_code = 0;

    gl_check_int = 0;
    gl_dsc_status = 0;


//---- HW Mode register initialize----
    hwmode_write(sSUSPEND);
    hostcnt_write(sDIRECT_ACS | sDIRECT_ENABLE | HOST_TYPE);

    mode_change(sREADY);
    wait(1);

    data_write(0xD0, 0x0004);   // SCLK ON
    data_write(0xF8, 0x0000);   // RESET clear
    data_write(0xF8, 0x0010);   // Initialize Register Enable
    data_write(0xF8, 0x0011);   // Initialize Sequence Start

    while (reg_read(REG) & 0x0002);
    data_write(0xD0, 0x0000);   // SCLK OFF
    data_write(0xF8, 0x0000);   // Initialize Register Disable
    data_write(0xF8, 0x1000);   // Compensation Enable

    data_write(0xD0, 0x0004);   // SCLK ON
    data_write(0xD9, 0x0000);   // BANK 0 select
    data_write(0xFA, 0x0300);   // BANK 0 Enable
    data_write(0xD9, 0x0100);   // BANK 1 select
    data_write(0xFA, 0x0300);   // BANK 1 Enable
    data_write(0xD9, 0x0200);   // BANK 2 select
    data_write(0xFA, 0x0300);   // BANK 2 Enable
    data_write(0xD9, 0x0300);   // BANK 3 select
    data_write(0xFA, 0x0300);   // BANK 3 Enable
    data_write(0xD9, 0x0400);   // BANK 4 select
    data_write(0xFA, 0x0300);   // BANK 4 Enable
    data_write(0xD9, 0x0500);   // BANK 5 select
    data_write(0xFA, 0x0300);   // BANK 5 Enable
    data_write(0xD9, 0x0600);   // BANK 6 select
    data_write(0xFA, 0x0300);   // BANK 6 Enable
    data_write(0xD9, 0x0700);   // BANK 7 select
    data_write(0xFA, 0x0300);   // BANK 7 Enable
    data_write(0xD9, 0x0800);   // BANK 8 select
    data_write(0xFA, 0x0300);   // BANK 8 Enable
    data_write(0xD9, 0x0900);   // BANK 9 select
    data_write(0xFA, 0x0300);   // BANK 9 Enable
    data_write(0xD9, 0x0a00);   // BANK10 select
    data_write(0xFA, 0x0300);   // BANK10 Enable
    data_write(0xD9, 0x0b00);   // BANK11 select
    data_write(0xFA, 0x0300);   // BANK11 Enable

//---- Clock Mode register initialize----
    ret_code = clk_div1_set(SCLK_DIV);  // SCLK = XIN / SCLK_DIV
    if (ret_code)
        err_code = ret_code | 0x01000;

    ret_code = clk_div2_set(LCDFR_DIV, LCDFR_DELAY);    // LCDFR = (SCLK / 4096) / LCDFR_DIV
    if (ret_code)
        err_code = ret_code | 0x01100;

    ret_code = clk_div3_set(CAMCKO_DIV);        // CAMCKO = XIN / CAMCKO_DIV
    if (ret_code)
        err_code = ret_code | 0x01200;

    clk_cnt_set(VD_EN | VDEDG_SEL | LCD_BASE_TIMING | sLCDFR_ENABLE | sSCK_ENABLE | sCMCK_ENABLE);      //LCDFR,SCLK,CAMCKO Enable

//---- Interrupt register initialize----
    data_write(INDEX, 0x0000);  //Interrupt status clear
    data_write(INTMSK, 0xffff); //all mask cleared
    data_write(INTCNT, INT_POL | INT_SEL);      //Interrupt control

//---- LED PWM Control initialize ----
    data_write(PWMCNT1, LEDCNT_POL | LEDCNT_EN);

//---- GIO register initialize----
    data_write(GIOCNT, 0x7f7b); //all input
    data_write(EXGIOCNT, 0xffff);       //all input
    
 //---- GIO2 high:cam i/f ON ----


   //    data_write(GIOOUT, 0x0004);                             
   data_write(GIOOUT, 0x0000);
    wait(5);
 
     bit_write(0x0120, 0x0003,0x0000);   // GPIO2 cortarl

//---- Memory register initialize----
    mem_point_set(0, 0);        //cam image storage position set
    data_write(MEMCNT, 0x0000);

    mem_acs_read_st(MEMACS_YUV);
    for (i = 0; i < 5; i++)
    {
        temp = reg_read(REG);
    }

//---- CAM register initialize ----
    cam_if_set(sCAMRST_OFF | VSPOL | HSPOL | CKPOL | RGBorYUV | RGBORD | YUVORD);       //cam I/F setup
    ret_code = cam_tim_set(CXS, CYS);   //A cam I/F frame start pixel position is set up
    if (ret_code)
        err_code = ret_code | 0x01300;

    data_write(CAMFLT, sDISABLE);       //fliter function:DISABLE
    ret_code = cam_size_set(CAM_HSIZE, CAM_VSIZE);      //Camera image size is set up
    if (ret_code)
        err_code = ret_code | 0x01400;

    data_write(CAMYD, 0x0000);  //A brightness element is expanded
    cam_lowpathfilter_set();

    mode_change(sREADY);
    wait(1);

    if (err_code)
        DEBUG_WRITE((0, 0, "%x", err_code));
    return (err_code);

}



//-----------------------------------------------------------------------------
//                      BU15xx CLOSE dispose (SUSPEND mode)
//-----------------------------------------------------------------------------
void aDSC_bu15xx_CLOSE(void)
{
    aDSC_Quit_Preview();

    if (bit_read(LCDCNT, bLCD_SEL) == sMAIN_ACS)
    {
        column_page_set(0, M_LCD_WSIZE - 1, 0, M_LCD_HSIZE - 1);
    }
    else
    {
        column_page_set(0, S_LCD_WSIZE - 1, 0, S_LCD_HSIZE - 1);
    }

    mode_change(sSUSPEND);

}



//-----------------------------------------------------------------------------
//                             Start Preview dispose
//-----------------------------------------------------------------------------
int aDSC_Start_Preview(const UINT16 st_x, const UINT16 st_y,
                       const UINT16 xsize, const UINT16 ysize,
                       const CAMSET * const cam)
{
    int err_code = 0;
    int ret_code = 0;

    aDSC_Quit_Preview();

    ret_code = lcd_trans_set(st_x, st_y, xsize, ysize);
    if (ret_code)
        err_code = ret_code | 0x1500;

    ret_code = cam_capture_set(cam);
    if (ret_code)
        err_code = ret_code | 0x1600;

    mode_change(sNVIEWER);      //VIEWER MODE

    if (err_code)
        DEBUG_WRITE((0, 0, "%x", err_code));
    return (err_code);
}



//-----------------------------------------------------------------------------
//                            Quit Preview dispose
//-----------------------------------------------------------------------------
UINT16 aDSC_Quit_Preview(void)
{
    UINT16 reg_data;

    reg_data = hwmode_read();
    if (reg_data == sNVIEWER)
    {
        wait_int0(bLCDED_MSK);
        /* William delete 20050524
        if (bit_read(LCDCNT, bLCD_SEL) == sMAIN_ACS)
        {
            column_page_set(0, M_LCD_WSIZE - 1, 0, M_LCD_HSIZE - 1);
        }
        else
        {
            column_page_set(0, S_LCD_WSIZE - 1, 0, S_LCD_HSIZE - 1);
        }
        */
    }
    else if (reg_data != sREADY)
    {
        mode_change(sREADY);
    }

    return (reg_data);
}

/*
int aDSC_ExOverlay_Preview(const UINT16 *p_Ovldata,const tExOvl* p_ExOvl )
{ 
    UINT16 cnt,u16Temp;
    UINT8 u8OvlNum;

    data_write(OVL_CNT,0x0012);

    data_write(OVL_TRANS,0xffff);
    data_write(OVL_TRMSK,0x0000);

    data_write(OVLSIZE,0x2020);	//32*32
    data_write(OVL_FRMST1,0x0000);
    data_write(OVL_ST1,0x0000);
    data_write(OVL_ED1,0x1f1f);

    data_write(MEM_ADR_OVL_ST,0x0000);
    data_write(MEM_ADR_OVL_ED,0x1f1f);

    bit_write(MEMCNT, bINCMTH | bADRINC, HIGH); //rectangle increment丄auto increment on

    memcnt_data = reg_read(INDEX);
    reg_write(INDEX, MEMACS_OVL);

    for(i=0;i<32*32;i++)
    {
        reg_write(REG, char_dat[i]);
    }
    bit_write(MEMCNT, bINCMTH | bADRINC, LOW); //rectangle increment丄auto increment off

//    data_write(OVL_CNT,0x0000);

        reg_write(INDEX, OVL_CNT);
        if ((reg_read(REG) & 0x0002) == 0)
        {
            wait_time = 0;
            x_step = 1;
            y_step = 1;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久亚洲二区三区| www.综合网.com| 国产一区欧美日韩| 成人在线一区二区三区| 91片在线免费观看| 91麻豆精品久久久久蜜臀| 久久久综合激的五月天| 自拍偷拍亚洲综合| 免费久久99精品国产| 成人亚洲一区二区一| 欧美日韩国产小视频在线观看| 精品国产免费视频| 一区二区三区 在线观看视频| 另类人妖一区二区av| 97久久超碰国产精品| 91精品午夜视频| 中文字幕中文字幕一区| 日韩高清不卡一区| av电影在线观看完整版一区二区| 欧美高清一级片在线| 中文在线一区二区| 青青草成人在线观看| 91亚洲精品乱码久久久久久蜜桃| 日韩一区和二区| 亚洲欧美成人一区二区三区| 精品一区二区三区日韩| 日本韩国一区二区| 国产亚洲精品bt天堂精选| 国产精品久久久久久久久免费相片| 久久精品视频免费| 日本高清无吗v一区| 欧美不卡123| 亚洲永久精品大片| 丁香一区二区三区| 日韩午夜av电影| 一区二区三区日韩在线观看| 国产精品一二三在| 日韩视频免费直播| 亚洲二区在线观看| 91亚洲精品乱码久久久久久蜜桃| 精品国产一区二区精华| 天天做天天摸天天爽国产一区 | kk眼镜猥琐国模调教系列一区二区| 欧美一级生活片| 亚洲国产综合色| 91小视频在线观看| 国产亚洲一区二区三区在线观看 | 欧美日韩午夜影院| 亚洲欧美色一区| 国产69精品久久久久毛片| 欧美白人最猛性xxxxx69交| 午夜久久电影网| 在线免费av一区| 亚洲激情在线激情| 99这里只有久久精品视频| 国产精品无码永久免费888| 国产美女精品人人做人人爽| 精品捆绑美女sm三区| 免费成人在线播放| 91精品免费在线| 日韩精品一区第一页| 欧美日韩久久一区| 亚洲韩国精品一区| 欧美日韩一二三| 午夜a成v人精品| 欧美精品aⅴ在线视频| 亚洲成人免费看| 欧美欧美欧美欧美首页| 婷婷国产在线综合| 91精品国产全国免费观看| 日日夜夜一区二区| 欧美一区二区三区免费在线看 | 欧美一区二区三区四区五区 | 欧美不卡一区二区| 国产在线精品国自产拍免费| 欧美精品一区二区三区视频| 久久福利视频一区二区| 欧美成人精精品一区二区频| 激情久久五月天| 国产拍揄自揄精品视频麻豆| 国产成人精品一区二区三区四区 | 国产精品99久久久久久久女警| 精品黑人一区二区三区久久| 国产一区二区电影| 国产精品欧美精品| 色综合久久久久久久| 亚洲成人午夜影院| 日韩精品最新网址| 国产传媒一区在线| 亚洲欧洲一区二区在线播放| 色噜噜夜夜夜综合网| 五月婷婷综合在线| 欧美变态凌虐bdsm| 成人美女视频在线观看18| 亚洲欧美日韩一区| 欧美理论电影在线| 久久精品国产77777蜜臀| 国产婷婷色一区二区三区四区| jlzzjlzz欧美大全| 亚洲超丰满肉感bbw| 26uuu亚洲综合色欧美| 不卡的电视剧免费网站有什么| 一区二区三区日韩欧美精品| 欧美一区二区私人影院日本| 国产成人一区二区精品非洲| 亚洲美女区一区| 91麻豆精品91久久久久同性| 国产精品一二三区在线| 亚洲男人都懂的| 日韩午夜av一区| www.一区二区| 日韩电影一区二区三区| 中文字幕精品在线不卡| 欧美日韩一区高清| 国产精品乡下勾搭老头1| 亚洲一区二区三区免费视频| 精品sm在线观看| 一本到不卡免费一区二区| 裸体健美xxxx欧美裸体表演| 国产精品国产三级国产aⅴ中文 | 一区二区三区在线免费播放| 日韩美女在线视频| 91麻豆视频网站| 久久福利视频一区二区| 亚洲激情男女视频| 26uuu久久综合| 在线观看一区不卡| 国产乱子轮精品视频| 亚洲成人一二三| 国产精品美女久久久久久久网站| 7777精品伊人久久久大香线蕉的 | 欧美国产日韩亚洲一区| 欧美人xxxx| 91在线国产观看| 韩国v欧美v日本v亚洲v| 亚洲国产sm捆绑调教视频| 国产精品视频一区二区三区不卡| 69堂成人精品免费视频| 91亚洲资源网| 国产精品夜夜爽| 免费成人av在线| 亚洲午夜久久久| 亚洲欧洲三级电影| 久久色视频免费观看| 欧美日韩情趣电影| 91尤物视频在线观看| 国产精品18久久久久久久久久久久| 午夜精品免费在线| 亚洲精品视频免费看| 欧美激情在线看| 精品日本一线二线三线不卡| 精品视频一区三区九区| 91丨porny丨在线| 国产综合成人久久大片91| 天堂精品中文字幕在线| 一区二区视频在线| 国产精品久久久久7777按摩| 久久久久9999亚洲精品| 日韩久久久久久| 欧美一二三四区在线| 欧美情侣在线播放| 欧美性大战久久久久久久| 91免费看视频| 99精品欧美一区二区三区小说| 国产精品系列在线观看| 国产在线精品一区二区三区不卡 | 精品乱人伦小说| 日韩一级片网站| 欧美一级欧美三级在线观看| 欧美日韩国产综合久久| 欧美日韩亚洲不卡| 欧美图片一区二区三区| 欧美中文字幕久久| 色综合色狠狠天天综合色| 99久久国产综合色|国产精品| 国产69精品久久久久毛片| 国产成人激情av| 成人综合激情网| www.一区二区| 91免费在线视频观看| 99久久99久久精品免费看蜜桃| 成人精品视频.| 99久久久精品免费观看国产蜜| 成人免费毛片片v| 波多野结衣在线aⅴ中文字幕不卡| 福利电影一区二区| av在线不卡电影| 欧美综合在线视频| 欧美日韩高清影院| 日韩一区和二区| 久久嫩草精品久久久久| 欧美激情一区二区三区| 中文字幕一区日韩精品欧美| 亚洲视频一二区| 亚洲成人动漫在线观看| 日韩高清欧美激情| 久久丁香综合五月国产三级网站| 国产精品白丝jk白祙喷水网站| 丰满少妇久久久久久久| 99精品在线免费|