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

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

?? s3c6410_post_proc.c

?? 6410BSP3
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this sample source code is subject to the terms of the Microsoft
// license agreement under which you licensed this sample source code. If
// you did not accept the terms of the license agreement, you are not
// authorized to use this sample source code. For the terms of the license,
// please see the license agreement between you and Microsoft or, if applicable,
// see the LICENSE.RTF on your install media or the root of your tools installation.
// THE SAMPLE SOURCE CODE IS PROVIDED "AS IS", WITH NO WARRANTIES OR INDEMNITIES.
//
//
// Copyright (c) Samsung Electronics. Co. LTD.  All rights reserved.
//
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.

Module Name:    s3c6410_post_proc.c

Abstract:       Implementation of Post Processor Control Library
                This module implements Low Level HW control 

Functions:


Notes:


--*/

#include <windows.h>
#include <bsp_cfg.h>
#include <s3c6410.h>
#include "s3c6410_post_proc.h"
#include "s3c6410_post_proc_macro.h"

#define POST_MSG(x)
#define POST_INF(x)    
#define POST_ERR(x)    RETAILMSG(TRUE, x)

#define REDUCE_VCLK_STOP_ON_LOCALPATH

static volatile S3C6410_POST_REG *g_pPostReg = NULL;
static tPostConfig g_PostConfig;

POST_ERROR Post_initialize_register_address(void *pPostReg)
{
    POST_ERROR error = POST_SUCCESS;

    POST_MSG((_T("[POST]++Post_initialize_register_address(0x%08x)\n\r"), pPostReg));

    if (pPostReg == NULL)
    {
        POST_ERR((_T("[POST:ERR] Post_initialize_register_address() : NULL pointer parameter\n\r")));
        error = POST_ERROR_NULL_PARAMETER;
    }
    else
    {
        g_pPostReg = (S3C6410_POST_REG *)pPostReg;
        POST_INF((_T("[POST:INF] g_pPostReg = 0x%08x\n\r"), g_pPostReg));
    }

    memset((void *)(&g_PostConfig), 0x0, sizeof(tPostConfig));

    POST_MSG((_T("[POST]--Post_initialize_register_address() : %d\n\r"), error));

    return error;
}

POST_ERROR Post_initialize(POST_OP_MODE Mode, POST_SCAN_MODE Scan,
                    POST_SRC_TYPE SrcType, unsigned int SrcBaseWidth, unsigned int SrcBaseHeight,
                    unsigned int SrcWidth, unsigned int SrcHeight, unsigned int SrcOffsetX, unsigned int SrcOffsetY,
                    POST_DST_TYPE DstType, unsigned int DstBaseWidth, unsigned int DstBaseHeight,
                    unsigned int DstWidth, unsigned int DstHeight, unsigned int DstOffsetX, unsigned int DstOffsetY)
{
    POST_ERROR error = POST_SUCCESS;

    POST_MSG((_T("[POST]++Post_initialize(%d, %d, %d, [%d, %d, %d, %d, %d, %d], %d, [%d, %d, %d, %d, %d, %d])\n\r"),
                Mode, Scan, SrcType, SrcBaseWidth, SrcBaseHeight, SrcWidth, SrcHeight, SrcOffsetX, SrcOffsetY,
                DstType, DstBaseWidth, DstBaseHeight, DstWidth, DstHeight, DstOffsetX, DstOffsetY));

    error = Post_set_mode(Mode, Scan, SrcType, DstType);
    if (error == POST_SUCCESS)
    {
#ifdef REDUCE_VCLK_STOP_ON_LOCALPATH
        // work-around for VCLK STOP when scaling down on Local Path State
        /*====================================================================*/
        if(Mode == POST_FREE_RUN_MODE)
        {
            if(SrcHeight >= 2*DstHeight)
            {
                int i=2;
                for(i=2;(SrcHeight >= i*DstHeight) && (i<8);i++);
                SrcBaseWidth *= i;
                SrcBaseHeight /= i;
                SrcHeight /= i;
                SrcOffsetY /= i;
            }
        }
        /*====================================================================*/
#endif
        Post_set_source_size(SrcBaseWidth, SrcBaseHeight, SrcWidth, SrcHeight, SrcOffsetX, SrcOffsetY);
        Post_set_destination_size(DstBaseWidth, DstBaseHeight, DstWidth, DstHeight, DstOffsetX, DstOffsetY);
        
        error = Post_update_condition();
    }

    POST_MSG((_T("[POST]--Post_initialize() : %d\n\r"), error));

    return error;
}

POST_ERROR Post_set_source_buffer(unsigned int AddrY, unsigned int AddrCb, unsigned int AddrCr)
{
    POST_ERROR error = POST_SUCCESS;

    POST_MSG((_T("[POST]++Post_set_source_buffer(0x%08x, 0x%08x, 0x%08x)\n\r"), AddrY, AddrCb, AddrCr));

    error = Post_set_dma_address(POST_SRC_ADDRESS, AddrY, AddrCb, AddrCr);

    POST_MSG((_T("[POST]--Post_set_source_buffer() : %d\n\r"), error));

    return error;
}

POST_ERROR Post_set_next_source_buffer(unsigned int AddrY, unsigned int AddrCb, unsigned int AddrCr)
{
    POST_ERROR error = POST_SUCCESS;

    POST_MSG((_T("[POST]++Post_set_next_source_buffer(0x%08x, 0x%08x, 0x%08x)\n\r"), AddrY, AddrCb, AddrCr));

    error = Post_set_dma_address(POST_NEXT_SRC_ADDRESS, AddrY, AddrCb, AddrCr);

    POST_MSG((_T("[POST]--Post_set_next_source_buffer() : %d\n\r"), error));

    return error;
}

POST_ERROR Post_set_destination_buffer(unsigned int AddrY, unsigned int AddrCb, unsigned int AddrCr)
{
    POST_ERROR error = POST_SUCCESS;

    POST_MSG((_T("[POST]++Post_set_destination_buffer(0x%08x, 0x%08x, 0x%08x)\n\r"), AddrY, AddrCb, AddrCr));

    if (g_PostConfig.DstType == POST_DST_FIFO_RGB888 || g_PostConfig.DstType == POST_DST_FIFO_YUV444)
    {
        POST_ERR((_T("[POST:ERR] Post_set_destination_buffer() : FIFO Mode does Not use DMA\n\r")));
        error = POST_ERROR_ILLEGAL_PARAMETER;
    }
    else
    {
        error = Post_set_dma_address(POST_DST_ADDRESS, AddrY, AddrCb, AddrCr);
    }

    POST_MSG((_T("[POST]--Post_set_destination_buffer() : %d\n\r"), error));

    return error;
}

POST_ERROR Post_set_next_destination_buffer(unsigned int AddrY, unsigned int AddrCb, unsigned int AddrCr)
{
    POST_ERROR error = POST_SUCCESS;

    POST_MSG((_T("[POST]++Post_set_next_destination_buffer(0x%08x, 0x%08x, 0x%08x)\n\r"), AddrY, AddrCb, AddrCr));

    if (g_PostConfig.DstType == POST_DST_FIFO_RGB888 || g_PostConfig.DstType == POST_DST_FIFO_YUV444)
    {
        POST_ERR((_T("[POST:ERR] Post_set_next_destination_buffer() : FIFO Mode does Not use DMA\n\r")));
        error = POST_ERROR_ILLEGAL_PARAMETER;
    }
    else
    {
        error = Post_set_dma_address(POST_NEXT_DST_ADDRESS, AddrY, AddrCb, AddrCr);
    }

    POST_MSG((_T("[POST]--Post_set_next_destination_buffer() : %d\n\r"), error));

    return error;
}

void Post_processing_start(void)
{
    POST_MSG((_T("[POST]++Post_processing_start()\n\r")));

    if (g_PostConfig.Mode == POST_FREE_RUN_MODE)    // for FIFO output mode
    {
        g_pPostReg->MODE |= AUTOLOAD_ENABLE;
    }

    g_pPostReg->POSTENVID |= POST_ENVID;

    POST_MSG((_T("[POST]--Post_processing_start()\n\r")));
}

void Post_processing_stop(void)
{
    POST_MSG((_T("[POST]++Post_processing_stop()\n\r")));

    if (g_pPostReg->MODE & AUTOLOAD_ENABLE)    // for FIFO output mode
    {
        // FIFO mode should be stopped by autoload disable
        g_pPostReg->MODE &= ~AUTOLOAD_ENABLE;
    }

    g_pPostReg->POSTENVID &= ~POST_ENVID;

    POST_MSG((_T("[POST]--Post_processing_stop() : %d\n\r"), error));
}

void Post_autoload_disable(void)
{
    POST_MSG((_T("[POST]++Post_autoload_disable()\n\r")));

    g_pPostReg->MODE &= ~AUTOLOAD_ENABLE;

    POST_MSG((_T("[POST]--Post_autoload_disable()\n\r")));
}

POST_STATE Post_get_processing_state(void)
{
    POST_STATE state;

    POST_MSG((_T("[POST]++Post_get_processing_state()\n\r")));

    if (g_pPostReg->POSTENVID & POST_ENVID)
    {
        state = POST_BUSY;
    }
    else
    {
        state = POST_IDLE;
    }

    POST_MSG((_T("[POST]--Post_get_processing_state() = %d\n\r"), state));

    return state;
}

void Post_enable_interrupt(void)
{
    POST_MSG((_T("[POST]++Post_enable_interrupt()\n\r")));

    g_PostConfig.bIntEnable = TRUE;

    g_pPostReg->MODE &= ~POSTINT_PEND;    // Pending Clear
    g_pPostReg->MODE |= POSTINT_ENABLE;    // Interrupt Enable

    POST_MSG((_T("[POST]--Post_enable_interrupt()\n\r")));
}

void Post_disable_interrupt(void)
{
    POST_MSG((_T("[POST]++Post_disable_interrupt()\n\r")));

    g_PostConfig.bIntEnable = FALSE;

    g_pPostReg->MODE &= ~POSTINT_ENABLE;    // Interrupt Disable
    g_pPostReg->MODE &= ~POSTINT_PEND;    // Pending Clear

    POST_MSG((_T("[POST]--Post_disable_interrupt()\n\r")));
}

BOOL Post_clear_interrupt_pending(void)
{
    BOOL IntPend = FALSE;

    POST_MSG((_T("[POST]++Post_clear_interrupt_pending()\n\r")));

    if (g_pPostReg->MODE & POSTINT_PEND)
    {
        g_pPostReg->MODE &= ~POSTINT_PEND;    // Pending Clear
        IntPend = TRUE;
    }

    POST_MSG((_T("[POST]--Post_clear_interrupt_pending()\n\r")));

    return IntPend;
}

static POST_ERROR Post_set_mode(POST_OP_MODE Mode, POST_SCAN_MODE Scan, POST_SRC_TYPE SrcType, POST_DST_TYPE DstType)
{
    POST_ERROR error = POST_SUCCESS;

    POST_MSG((_T("[POST]++Post_set_mode(%d, %d, %d, %d)\n\r"), Mode, Scan, SrcType, DstType));

    g_PostConfig.Mode = Mode;
    g_PostConfig.Scan = Scan;
    g_PostConfig.SrcType = SrcType;
    g_PostConfig.DstType = DstType;

    // For some application PostProcessor May be need to faster CLK
    // setting for faster CLK : CLKVALUP_ALWAYS | CLKVAL_F(0) | CLKDIR_DIRECT | CLKSEL_F_HCLK | CSC_R2Y_WIDE | CSC_Y2R_WIDE | IRQ_LEVEL
    g_pPostReg->MODE = CLKVALUP_ALWAYS | CLKVAL_F(2) | CLKDIR_DIVIDED | CLKSEL_F_HCLK | CSC_R2Y_NARROW | CSC_Y2R_NARROW | IRQ_LEVEL;    // Clock = HCLK/2

    if (g_PostConfig.bIntEnable)
    {
        g_pPostReg->MODE |= POSTINT_ENABLE;
    }

    if (Mode == POST_PER_FRAME_MODE)
    {
        g_pPostReg->MODE |= AUTOLOAD_DISABLE;
    }
    else if (Mode == POST_FREE_RUN_MODE)
    {
        g_pPostReg->MODE |= AUTOLOAD_ENABLE;
    }
    else
    {
        POST_ERR((_T("[POST:ERR] Post_set_mode() : Unknown Operation Mode %d)\n\r"), Mode));
        return POST_ERROR_ILLEGAL_PARAMETER;
    }

    if (Scan == POST_PROGRESSIVE)
    {
        g_pPostReg->MODE |= PROGRESSIVE;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲自拍与偷拍| 国产偷国产偷亚洲高清人白洁| 国产精品久久久久天堂| 国产91在线观看| 国产精品天天看| 成人av片在线观看| 亚洲欧美乱综合| 欧美网站一区二区| 麻豆精品国产91久久久久久| 精品av久久707| 高清beeg欧美| 亚洲国产中文字幕在线视频综合| 欧美日韩情趣电影| 日本va欧美va瓶| 欧美激情在线看| 色婷婷久久久久swag精品| 亚洲电影一级黄| 日韩精品一区二区在线| 国产91丝袜在线观看| 夜夜精品浪潮av一区二区三区| 在线播放91灌醉迷j高跟美女| 久久国产生活片100| 日本一区二区电影| 欧美三级三级三级| 国产精品888| 亚洲一二三区视频在线观看| 欧美mv日韩mv国产网站app| 成人性生交大片| 午夜国产精品一区| 国产欧美精品在线观看| 欧美综合亚洲图片综合区| 国产一区二区电影| 婷婷六月综合网| 国产欧美日韩在线看| 欧美性大战xxxxx久久久| 国产一二精品视频| 午夜精品成人在线| 国产精品无人区| 日韩欧美中文字幕精品| 99re成人精品视频| 麻豆精品视频在线观看免费| 亚洲伦理在线精品| 久久久亚洲综合| 7777精品伊人久久久大香线蕉| 国产suv精品一区二区三区| 天天色综合天天| 亚洲欧美日韩国产手机在线| 久久久久久99精品| 欧美精品在线观看播放| 99在线精品免费| 国产精品一区不卡| 毛片不卡一区二区| 丝袜美腿高跟呻吟高潮一区| 亚洲视频免费在线| 国产天堂亚洲国产碰碰| 日韩三级精品电影久久久 | 亚洲欧美aⅴ...| 26uuu精品一区二区在线观看| 欧美色图激情小说| 91免费观看国产| 成人亚洲精品久久久久软件| 黄色日韩三级电影| 日韩国产欧美三级| 亚洲v中文字幕| 亚洲乱码日产精品bd| 中文字幕在线不卡一区二区三区 | 欧美久久久久久久久中文字幕| 成人毛片老司机大片| 国产精品99久久久久久有的能看 | 性做久久久久久免费观看 | 国产精品视频一二三区| 26uuu亚洲| 久久久久青草大香线综合精品| 精品欧美乱码久久久久久1区2区| 欧美一级日韩一级| 欧美人牲a欧美精品| 欧美日韩美女一区二区| 欧美人与禽zozo性伦| 欧美三级韩国三级日本三斤| 欧美日韩一区不卡| 欧美高清视频在线高清观看mv色露露十八 | 韩国女主播成人在线观看| 日本伊人色综合网| 精品一区二区免费在线观看| 免费在线看一区| 韩国理伦片一区二区三区在线播放| 久久成人久久鬼色| 国产精品一区二区免费不卡| 成人av手机在线观看| 91亚洲国产成人精品一区二三| 91老司机福利 在线| 欧美性受极品xxxx喷水| 欧美福利一区二区| 精品国产91久久久久久久妲己| 精品日产卡一卡二卡麻豆| 欧美—级在线免费片| 亚洲欧美在线视频观看| 亚洲国产中文字幕| 老司机精品视频一区二区三区| 加勒比av一区二区| av激情综合网| 欧美日韩一级二级| 亚洲精品一区二区三区蜜桃下载| 欧美极品美女视频| 亚洲一二三四在线观看| 蜜桃av一区二区三区电影| 国产不卡视频在线观看| 欧美影院一区二区三区| 精品国产髙清在线看国产毛片| 国产精品婷婷午夜在线观看| 亚洲成人久久影院| 国产乱子轮精品视频| 91免费视频观看| 精品国产不卡一区二区三区| 亚洲男人天堂av| 精品制服美女丁香| 91在线码无精品| 欧美大肚乱孕交hd孕妇| 中文字幕一区二区三区四区不卡| 亚洲成人动漫av| 国产成人日日夜夜| 欧美精三区欧美精三区| 国产农村妇女毛片精品久久麻豆 | 亚洲综合偷拍欧美一区色| 日本美女一区二区三区视频| 国产.欧美.日韩| 欧美日韩成人一区二区| 国产视频911| 午夜精品福利视频网站| jlzzjlzz国产精品久久| 欧美videos大乳护士334| 亚洲日穴在线视频| 国产一区二区美女| 欧美网站一区二区| 日韩毛片视频在线看| 国内久久婷婷综合| 欧美日本乱大交xxxxx| 1000部国产精品成人观看| 韩国中文字幕2020精品| 777欧美精品| 亚洲理论在线观看| 99免费精品在线| 久久九九影视网| 日韩av一二三| 欧美日韩成人一区| 亚洲成人一区在线| 色悠久久久久综合欧美99| 国产喷白浆一区二区三区| 美国毛片一区二区三区| 91麻豆精品国产91久久久更新时间 | 成人动漫一区二区三区| 精品久久久网站| 久久狠狠亚洲综合| 日韩美女在线视频| 日韩精品欧美成人高清一区二区| 91国产福利在线| 亚洲精品国产一区二区三区四区在线 | 国产精品久久久久一区二区三区 | 欧美精品v日韩精品v韩国精品v| 亚洲欧洲精品天堂一级| av在线播放一区二区三区| 国产精品麻豆久久久| 成人午夜在线视频| 中文一区一区三区高中清不卡| 国产一区视频在线看| 亚洲精品在线观| 国产精品原创巨作av| 久久久一区二区| 国产91精品欧美| 国产精品视频免费看| 成人h动漫精品一区二| 亚洲人成网站精品片在线观看| 99re亚洲国产精品| 亚洲精品乱码久久久久久久久| 91啪亚洲精品| 亚洲成人手机在线| 欧美电影免费提供在线观看| 久久国产尿小便嘘嘘| 精品国产人成亚洲区| 国产精品夜夜嗨| 欧美国产综合一区二区| 99久久伊人网影院| 亚洲一区影音先锋| 欧美二区乱c少妇| 麻豆视频观看网址久久| 26uuu欧美| 91色婷婷久久久久合中文| 亚洲卡通动漫在线| 欧美日韩国产精品成人| 久色婷婷小香蕉久久| 国产拍揄自揄精品视频麻豆| 91美女片黄在线| 日产国产高清一区二区三区| 久久精品视频一区二区| www.66久久| 蜜臀av在线播放一区二区三区| 国产亚洲欧美日韩日本| 91久久精品国产91性色tv| 麻豆精品国产91久久久久久| 国产精品理论片|