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

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

?? pci2.c

?? eCos/RedBoot for勤研ARM AnywhereII(4510) 含全部源代碼
?? C
字號:
//==========================================================================
//
//        pci2.c
//
//        Test PCI library's resource allocation.
//
//==========================================================================
//####ECOSGPLCOPYRIGHTBEGIN####
// -------------------------------------------
// This file is part of eCos, the Embedded Configurable Operating System.
// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
//
// eCos is free software; you can redistribute it and/or modify it under
// the terms of the GNU General Public License as published by the Free
// Software Foundation; either version 2 or (at your option) any later version.
//
// eCos is distributed in the hope that it will be useful, but WITHOUT ANY
// WARRANTY; without even the implied warranty of MERCHANTABILITY or
// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
// for more details.
//
// You should have received a copy of the GNU General Public License along
// with eCos; if not, write to the Free Software Foundation, Inc.,
// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
//
// As a special exception, if other files instantiate templates or use macros
// or inline functions from this file, or you compile this file and link it
// with other works to produce a work based on this file, this file does not
// by itself cause the resulting work to be covered by the GNU General Public
// License. However the source code for this file must still be made available
// in accordance with section (3) of the GNU General Public License.
//
// This exception does not invalidate any other reasons why a work based on
// this file might be covered by the GNU General Public License.
//
// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
// at http://sources.redhat.com/ecos/ecos-license/
// -------------------------------------------
//####ECOSGPLCOPYRIGHTEND####
//==========================================================================
//#####DESCRIPTIONBEGIN####
//
// Author(s):     jskov
// Contributors:  jskov
// Date:          1999-03-17
// Description: Simple test that prints out information about found
//              PCI devices. Entirely passive - no configuration happens.
// 
//####DESCRIPTIONEND####

#include <pkgconf/system.h>

#include <cyg/infra/diag.h>             // diag_printf
#include <cyg/infra/testcase.h>         // test macros
#include <cyg/infra/cyg_ass.h>          // assertion macros

// Package requirements
#if defined(CYGPKG_IO_PCI) && defined(CYGPKG_KERNEL)

#include <pkgconf/kernel.h>
#include <pkgconf/io_pci.h>
#include <cyg/io/pci.h>
#include <cyg/hal/hal_arch.h>

// Package option requirements
#if defined(CYGFUN_KERNEL_API_C) && defined(CYG_PCI_PRESENT)

#include <cyg/kernel/kapi.h>

unsigned char stack[CYGNUM_HAL_STACK_SIZE_TYPICAL];
cyg_thread thread_data;
cyg_handle_t thread_handle;

void
pci_test( void )
{
    cyg_pci_device dev_info;
    CYG_PCI_ADDRESS64 mem_base;
    CYG_PCI_ADDRESS64 mem_assigned_addr;
    CYG_PCI_ADDRESS32 io_base;
    CYG_PCI_ADDRESS32 io_assigned_addr;

    // Verify that space type requests are checked.
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_IO;
    CYG_TEST_CHECK(!cyg_pci_allocate_memory_priv(&dev_info, 0, &mem_base, 
                                                 &mem_assigned_addr),
                   "cyg_pci_allocate_memory_priv accepted IO request");
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_MEM;
    CYG_TEST_CHECK(!cyg_pci_allocate_io_priv(&dev_info, 0, &io_base, 
                                             &io_assigned_addr),
                   "cyg_pci_allocate_io_priv accepted MEM request");

    // Check allocation and alignment of IO space
    io_base = 0x0000;
    // Size 4
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_IO | 0xfffffffc;
    CYG_TEST_CHECK(cyg_pci_allocate_io_priv(&dev_info, 0, &io_base, 
                                            &io_assigned_addr),
                   "cyg_pci_allocate_io_priv(4) failed");
    CYG_TEST_CHECK(0x0004 == io_base, 
                   "cyg_pci_allocate_io_priv(4) size failed");
    CYG_TEST_CHECK(0x0000 == io_assigned_addr,
                   "cyg_pci_allocate_io_priv(4) align failed");
    // Size 8 (alignment required)
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_IO | 0xfffffff8;
    CYG_TEST_CHECK(cyg_pci_allocate_io_priv(&dev_info, 0, &io_base, 
                                            &io_assigned_addr),
                   "cyg_pci_allocate_io_priv(8) failed");
    CYG_TEST_CHECK(0x0010 == io_base, 
                   "cyg_pci_allocate_io_priv(8) size failed");
    CYG_TEST_CHECK(0x0008 == io_assigned_addr,
                   "cyg_pci_allocate_io_priv(8) align failed");
    // Size 16 (no alignment required)
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_IO | 0xfffffff0;
    CYG_TEST_CHECK(cyg_pci_allocate_io_priv(&dev_info, 0, &io_base, 
                                            &io_assigned_addr),
                   "cyg_pci_allocate_io_priv(16) failed");
    CYG_TEST_CHECK(0x0020 == io_base, 
                   "cyg_pci_allocate_io_priv(16) size failed");
    CYG_TEST_CHECK(0x0010 == io_assigned_addr,
                   "cyg_pci_allocate_io_priv(16) align failed");
    // Size 64 (alignment required)
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_IO | 0xffffffc0;
    CYG_TEST_CHECK(cyg_pci_allocate_io_priv(&dev_info, 0, &io_base,
                                            &io_assigned_addr),
                   "cyg_pci_allocate_io_priv(64) failed");
    CYG_TEST_CHECK(0x0080 == io_base,
                   "cyg_pci_allocate_io_priv(64) size failed");
    CYG_TEST_CHECK(0x0040 == io_assigned_addr,
                   "cyg_pci_allocate_io_priv(64) align failed");
    // Size 256 (alignment required)
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_IO | 0xffffff00;
    CYG_TEST_CHECK(cyg_pci_allocate_io_priv(&dev_info, 0, &io_base,
                                            &io_assigned_addr),
                   "cyg_pci_allocate_io_priv(256) failed");
    CYG_TEST_CHECK(0x0200 == io_base, 
                   "cyg_pci_allocate_io_priv(256) size failed");
    CYG_TEST_CHECK(0x0100 == io_assigned_addr,
                   "cyg_pci_allocate_io_priv(256) align failed");

    // Check allocation and alignment of MEM space
    mem_base = 0x00000000;
    // Size 16 (no alignment required)
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_MEM | 0xfffffff0;
    CYG_TEST_CHECK(cyg_pci_allocate_memory_priv(&dev_info, 0, &mem_base, 
                                                &mem_assigned_addr),
                   "cyg_pci_allocate_memory_priv(16) failed");
    CYG_TEST_CHECK(0x00000010 == mem_base, 
                   "cyg_pci_allocate_memory_priv(16) size failed");
    CYG_TEST_CHECK(0x00000000 == mem_assigned_addr,
                   "cyg_pci_allocate_memory_priv(16) align failed");
    // Size 64 (alignment required - <1MB)
    dev_info.base_size[0] = (CYG_PCI_CFG_BAR_SPACE_MEM 
                             | CYG_PRI_CFG_BAR_MEM_TYPE_1M
                             | 0xffffffc0);
    CYG_TEST_CHECK(cyg_pci_allocate_memory_priv(&dev_info, 0, &mem_base, 
                                                &mem_assigned_addr),
                   "cyg_pci_allocate_memory_priv(64/<1MB) failed");
    CYG_TEST_CHECK(0x00000080 == mem_base, 
                   "cyg_pci_allocate_memory_priv(64/<1MB) size failed");
    CYG_TEST_CHECK(0x00000040 == mem_assigned_addr,
                   "cyg_pci_allocate_memory_priv(64/<1MB) align failed");
    // Size 1MB (alignment required)
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_MEM | 0xfff00000;
    CYG_TEST_CHECK(cyg_pci_allocate_memory_priv(&dev_info, 0, &mem_base, 
                                                &mem_assigned_addr),
                   "cyg_pci_allocate_memory_priv(1MB) failed");
    CYG_TEST_CHECK(0x00200000 == mem_base, 
                   "cyg_pci_allocate_memory_priv(1MB) size failed");
    CYG_TEST_CHECK(0x00100000 == mem_assigned_addr,
                   "cyg_pci_allocate_memory_priv(1MB) align failed");
    // Size 16MB (alignment required)
    dev_info.base_size[0] = CYG_PCI_CFG_BAR_SPACE_MEM | 0xff000000;
    CYG_TEST_CHECK(cyg_pci_allocate_memory_priv(&dev_info, 0, &mem_base, 
                                                &mem_assigned_addr),
                   "cyg_pci_allocate_memory_priv(16MB) failed");
    CYG_TEST_CHECK(0x02000000 == mem_base, 
                   "cyg_pci_allocate_memory_priv(16MB) size failed");
    CYG_TEST_CHECK(0x01000000 == mem_assigned_addr,
                   "cyg_pci_allocate_memory_priv(16MB) align failed");
    // Size 32 (no alignment required - <1MB - FAILS!)
    // Note: When more clever allocation has been made for the bottom
    // 1MB of PCI memory space, this test needs to be made more elaborate.
    dev_info.base_size[0] = (CYG_PCI_CFG_BAR_SPACE_MEM 
                             | CYG_PRI_CFG_BAR_MEM_TYPE_1M
                             | 0xffffffe0);
    CYG_TEST_CHECK(!cyg_pci_allocate_memory_priv(&dev_info, 0, &mem_base, 
                                                 &mem_assigned_addr),
                 "cyg_pci_allocate_memory_priv(32/<1MB) unexpectedly worked!");
    
    // TBD: Check 64bit MEM allocation.

    CYG_TEST_PASS_FINISH("pci2 test OK");
}

void
cyg_start(void)
{
    CYG_TEST_INIT();
    cyg_thread_create(10,                   // Priority - just a number
                      (cyg_thread_entry_t*)pci_test,         // entry
                      0,                    // 
                      "pci_thread",     // Name
                      &stack[0],            // Stack
                      CYGNUM_HAL_STACK_SIZE_TYPICAL,           // Size
                      &thread_handle,       // Handle
                      &thread_data          // Thread data structure
        );
    cyg_thread_resume(thread_handle);
    cyg_scheduler_start();
}

#else // CYGFUN_KERNEL_API_C && CYG_PCI_PRESENT
#define N_A_MSG "Needs kernel C API & PCI platform support"
#endif

#else // CYGPKG_IO_PCI && CYGPKG_KERNEL
#define N_A_MSG "Needs IO/PCI and Kernel"
#endif

#ifdef N_A_MSG
void
cyg_start( void )
{
    CYG_TEST_INIT();
    CYG_TEST_NA( N_A_MSG);
}
#endif // N_A_MSG

// EOF pci1.c

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久夜精品精品免费| 在线观看视频一区二区| 青青草成人在线观看| 五月婷婷激情综合网| 亚洲一区二区三区四区五区黄| 国产精品的网站| 亚洲裸体xxx| 洋洋成人永久网站入口| 伊人夜夜躁av伊人久久| 亚洲国产日韩a在线播放| 亚洲综合色丁香婷婷六月图片| 亚洲一区在线电影| 免费成人美女在线观看| 激情综合网av| 成人一级片网址| 欧美中文一区二区三区| 91麻豆精品国产91久久久使用方法| 欧美日韩国产综合视频在线观看| 91精品国产综合久久精品性色| 日韩午夜av电影| 久久精品欧美一区二区三区不卡| 国产日韩综合av| 亚洲图片欧美一区| 国产在线精品不卡| 色综合久久综合网欧美综合网| 欧美日韩在线播放三区四区| 日韩一二三区视频| 中文一区一区三区高中清不卡| 亚洲色图清纯唯美| 美女一区二区视频| 97精品久久久午夜一区二区三区 | 久久草av在线| 国产mv日韩mv欧美| 在线观看91av| 国产欧美日本一区二区三区| 一区二区三区四区在线| 久草中文综合在线| 91精彩视频在线| 国产日韩三级在线| 欧美96一区二区免费视频| 成人免费观看视频| 欧美一级黄色大片| 亚洲视频图片小说| 国产一二三精品| 欧美性videosxxxxx| 国产亚洲欧美色| 丝袜诱惑制服诱惑色一区在线观看 | 色欧美乱欧美15图片| 欧美一级日韩免费不卡| 亚洲欧美日韩国产中文在线| 久久99精品国产麻豆婷婷| 欧美日韩一本到| 亚洲欧美国产77777| 国产麻豆精品一区二区| 7777精品伊人久久久大香线蕉完整版| 国产精品久久久久久久午夜片| 蜜桃久久精品一区二区| 欧美日韩国产中文| 一级日本不卡的影视| 不卡av在线网| 国产精品色哟哟网站| 国产最新精品精品你懂的| 777亚洲妇女| 视频一区视频二区在线观看| 91国产精品成人| 亚洲欧美另类综合偷拍| 成人久久18免费网站麻豆| 久久久久久9999| 国产福利精品导航| 久久久亚洲高清| 日韩电影免费一区| 欧美精品自拍偷拍| 天堂久久久久va久久久久| 欧美日韩美女一区二区| 亚洲综合成人在线视频| 欧美日韩中文另类| 亚洲国产日韩a在线播放| 欧美日韩国产片| 日韩国产精品久久久| 欧美日高清视频| 性久久久久久久久| 欧美高清激情brazzers| 日韩二区三区四区| 欧美一区永久视频免费观看| 日本视频中文字幕一区二区三区 | 久久99精品久久久久久| 2021久久国产精品不只是精品| 国产乱码精品一区二区三区忘忧草 | 欧美午夜视频网站| 日韩电影免费在线看| 日韩免费性生活视频播放| 国产成人av影院| 亚洲欧美日韩综合aⅴ视频| 欧美日韩视频不卡| 国产在线播精品第三| 欧美国产国产综合| 欧美三级韩国三级日本三斤| 日日夜夜精品视频天天综合网| 亚洲精品在线免费观看视频| 国产69精品一区二区亚洲孕妇| 国产精品乱人伦| 在线观看免费一区| 国产综合成人久久大片91| 亚洲天堂免费看| 欧美一区二区精美| 91在线看国产| 日韩av二区在线播放| 中文字幕精品三区| 日韩一区二区三免费高清| 高清成人在线观看| 丝袜美腿成人在线| 亚洲欧美一区二区三区国产精品| 欧美一级二级三级蜜桃| 成人黄色电影在线| 免费视频一区二区| 亚洲日本在线a| 久久欧美中文字幕| 欧美日韩国产乱码电影| 成人动漫一区二区在线| 美女国产一区二区| 一区二区视频在线| 国产片一区二区| 欧美一级二级三级蜜桃| 色噜噜夜夜夜综合网| 成人综合婷婷国产精品久久免费| 石原莉奈在线亚洲三区| 亚洲免费av在线| 国产午夜精品一区二区三区视频| 欧美高清精品3d| 色狠狠桃花综合| 99久久久精品免费观看国产蜜| 久久99精品久久久久久久久久久久| 亚洲精品福利视频网站| 国产精品另类一区| 久久久久久夜精品精品免费| 欧美一级生活片| 在线电影国产精品| 欧美三级中文字| 在线视频观看一区| 91蜜桃在线免费视频| 粉嫩久久99精品久久久久久夜| 久久激五月天综合精品| 午夜精品一区二区三区电影天堂| 亚洲男人天堂av| 夜色激情一区二区| 亚洲一区二区三区四区五区中文| 中文字幕一区二区三区在线观看| 久久久久国产精品厨房| 久久精品一区二区三区不卡牛牛| 欧美成人福利视频| 久久综合久久鬼色| 久久久久久久久久久黄色| 欧美成人精品3d动漫h| 日韩欧美一区二区免费| 日韩一区二区三区四区| 日韩三级免费观看| 欧美哺乳videos| 久久久久久影视| |精品福利一区二区三区| 亚洲精品国产第一综合99久久 | 五月婷婷久久丁香| 日韩av电影免费观看高清完整版在线观看| 亚洲gay无套男同| 蜜桃久久av一区| 国产精品69久久久久水密桃| 成人app在线观看| 日本电影亚洲天堂一区| 在线成人av影院| 久久精品视频网| 亚洲精品视频自拍| 三级欧美韩日大片在线看| 精品一区二区三区在线播放 | 在线不卡欧美精品一区二区三区| 制服视频三区第一页精品| 欧美v日韩v国产v| 国产精品视频观看| 一区二区三区日韩欧美| 青青青伊人色综合久久| 成人午夜激情在线| 欧美性猛片xxxx免费看久爱| 日韩女优制服丝袜电影| 欧美国产激情一区二区三区蜜月| 亚洲免费高清视频在线| 国产自产v一区二区三区c| av一区二区三区黑人| 欧美一区国产二区| 国产精品久久毛片av大全日韩| 亚洲国产精品久久艾草纯爱| 韩国v欧美v亚洲v日本v| 在线免费亚洲电影| 国产视频一区二区三区在线观看| 亚洲婷婷在线视频| 国内成人精品2018免费看| 在线观看精品一区| 国产精品视频一二| 免播放器亚洲一区| 91久久国产最好的精华液| 精品乱码亚洲一区二区不卡| 亚洲综合免费观看高清完整版| 国产一区二区不卡在线|