青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 297,  comments - 15,  trackbacks - 0

The DMA is another two chips on your motherboard (usually is an Intel 8237A-5 chips) that allow you (the programmer) to offload data transfers between I/O boards. DMA actually stands for 'Direct Memory Access'.

DMA can work: memory->I/O, I/O->memory. The memory->memory transfer doesn't work. It doesn't matter because ISA DMA is slow as hell and thus is unusable. Futhermore, using DMA for zeroing out memory would massacre the contents of memory caches.

What about caches and DMA? L1 and L2 caches work absolutely transparently. When DMA writes to memory, caches autmatically load or least invalidate the data that go into the memory. When DMA reads memory, caches supply the unwritten bytes so not old but new values are tranferred to the peripheral.

There are signals DACK, DRQ, and TC. When a peripheral wants to move a byte or 2 bytes into memory (is dependent on whether 8 bit or 16 bit DMA channel is in use -- 0,1,2,3 are 8-bit, 5,6,7 are 16-bit), it issues DRQ. DMA controller chats with CPU and after some time DMA controller issues DACK. Seeing DACK, the peripheral puts it's byte on data bus, DMA controller takes it and puts it in memory. If it was the last byte/word to move, DMA controller sets up also TC during the DACK. When peripheral sees TC, it is possible it will not want any more movements,

In the other direction, everything is the same, but first the byte/word is fetched from the memory and then DACK is generated and the peripheral takes the data.

DMA controller has only 8-bit address counter inside. There is external ALS573 counter for each chip so it makes programmer see it as DMA controller had 16 bits of address counter per channel inside. There are more 8 bits of address per channel of so called page register in LS612 that unfortunately do not increment as those in ALS573. All these 24 bits can address 16777216 of distict addresses.

Recapitulation: for each channel, independently, you see 16 bits of auto-incrementing counter, and 8 bits of page register which doesn't increment.

The difference between 16-bit DMA channels and 8-bit DMA channels is that the address bits for 16-bit channels are wired one bit left to the address bus so every address is 2 times bigger. The lowest bit is 0. The highest bit of page register would fit into bit 24 which is not on ISA so that it is left unconnected. The bus control logic is wired for 16-bit channels in a manner every single DMA transfer, a 16-bit cycle is generated, so ISA device puts 16 bits onto the bus at the time. I don't know what happens if you use 16-bit DMA channel with XT peripheral. I guess it could work but only be slower.

8-bit DMA: increments by 1, cycles inside 65536 bytes, addresses 16MB, moves 8 bits a time.

16-bit DMA: increments by 2, goes only over even addresses, cycles inside 131072 bytes, addresses 16MB, moves 16 bits a time. Uses 16-bit ISA I/O cycle so it takes less ticks to make one move that the 8-bit DMA.

An example of DMA usage would be the Sound Blaster's ability to play samples in the background. The CPU sets up the sound card and the DMA. When the DMA is told to 'go', it simply shovels the data from RAM to the card. Since this is done off-CPU, the CPU can do other things while the data is being transferred.

Enough basics. Here's how you program the DMA chip.


When you want to start a DMA transfer, you need to know several things:

  • Number of DMA channel you want to use
  • What page to use
  • The offset in the page
  • The length
  • How to tell you peripheral to ask for DMA

  • You cannot transfer more than 64K or 128K of data in one shot, and
  • You cannot cross a page boundary. If you cross it, the lower 16 or 17 bits of address will simply wrap and you only suddenly jump 65536 or 131072 bytes lower that where you expected. It will be absolutely OK and no screw up will be performed. If you will take it in account in your program you can use it.

Restriction #1 is rather easy to get around. Simply transfer the first block, and when the transfer is done, send the next block.

For those of you not familiar with pages, I'll try to explain.

Picture the first 16MB region of memory in your system. It is divided into 256 pages of 64K or 128 pages of 128K. Every page starts at a multiple of 65536 or 131072. They are numbered from 0 to 255 or from 0 to 127.

In plain English, the page is the highest 8 bits or 7 bits of the absolute 24 bit address of our memory location. The offset is the lower 16 or 17 bits of the absolute 24 bit address.

Now that we know where our data is, we need to find the length.

The DMA has a little quirk on length. The true length sent to the DMA is actually length + 1. So if you send a zero length to the DMA, it actually transfers one byte or word, whereas if you send 0xFFFF, it transfers 64K or 128K. I guess they made it this way because it would be pretty senseless to program the DMA to do nothing (a length of zero), and in doing it this way, it allowed a full 64K or 128K span of data to be transferred.

Now that you know what to send to the DMA, how do you actually start it? This enters us into the different DMA channels.

The following chart will describe each channel and it's corresponding port number:

DMA ChannelPageAddressCount
087h0h1h
183h2h3h
281h4h5h
382h6h7h
48FhC0hC2h
58BhC4hC6h
689hC8hCAh
78AhCChCEh

DMA 4. Doesn't exist. DMA 4 is used to cascade the two 8237A chips. When first 8237A wants to DMA, it issues "HRQ" to second chip's DRQ 4. The second chip thinks DMA 4 is wanna be made so issues DRQ 4 to the first chip's HLDA. First chip makes it's own DMA 0-3, then sends to the second "OK second chip, my DMA 4 is complete" and second chip knows it's free on the bus. If this mechanism would not work, the two chips could peck each other on the BUS and the PC would screw up. :+)

from:
posted on 2010-11-14 19:23 chatler 閱讀(703) 評(píng)論(0)  編輯 收藏 引用 所屬分類: OS
<2010年11月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個(gè)博客還是不錯(cuò),雖然做的東西和我不大相關(guān),覺得看看還是有好處的

network

OSS

  • Google Android
  • Android is a software stack for mobile devices that includes an operating system, middleware and key applications. This early look at the Android SDK provides the tools and APIs necessary to begin developing applications on the Android platform using the Java programming language.
  • os161 file list

overall

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美日韩国产片| 性欧美video另类hd性玩具| 中文精品在线| 久久这里只精品最新地址| 艳女tv在线观看国产一区| 国内不卡一区二区三区| 国产精品欧美日韩| 国产一区二区高清视频| 国产精品九九久久久久久久| 亚洲电影免费在线| 国产精品一国产精品k频道56| 久久伊人亚洲| 一区二区三区精品视频| 美女精品网站| 欧美午夜一区| 欧美成人午夜视频| 免费一级欧美片在线观看| 在线免费观看欧美| 欧美视频不卡| 正在播放日韩| 久久精品国产第一区二区三区| 国产精品一区二区三区久久久| 国产精品美女久久久久久2018| 欧美色偷偷大香| 亚洲视频中文字幕| 欧美精品一区二区高清在线观看| 美女网站久久| 一区二区三区四区国产| 久久亚洲精品一区| 欧美日韩亚洲一区三区| 欧美一区二区三区在线免费观看| 快射av在线播放一区| 亚洲精品亚洲人成人网| 香蕉免费一区二区三区在线观看| 牛夜精品久久久久久久99黑人| 你懂的国产精品| 久久久精品性| 欧美大香线蕉线伊人久久国产精品| 亚洲一区二区高清视频| 欧美影院午夜播放| 在线一区免费观看| 亚洲综合精品一区二区| 日韩午夜一区| 一二美女精品欧洲| 亚洲视频一区在线观看| 欧美日韩国产一级| 久久裸体艺术| 亚洲精品视频一区| 亚洲卡通欧美制服中文| 欧美一区三区三区高中清蜜桃| 精品成人一区二区三区| 一区二区三区鲁丝不卡| 伊人婷婷欧美激情| 欧美激情视频网站| 国产欧美精品xxxx另类| 欧美一进一出视频| 欧美午夜精品久久久| 欧美黄色免费| 加勒比av一区二区| 国产精品成人在线观看| 午夜精品久久久久久久蜜桃app | 亚洲高清在线播放| av成人激情| 91久久在线视频| 欧美精品色综合| 午夜一区二区三区不卡视频| 欧美成人一区二区三区片免费| 亚洲视频福利| 欧美日韩国产黄| 最新热久久免费视频| 亚洲精品极品| 91久久国产自产拍夜夜嗨| 欧美一区二区视频97| 亚洲伊人第一页| 免费h精品视频在线播放| 亚洲每日在线| 欧美99久久| 久久综合色一综合色88| 一区三区视频| 亚洲第一成人在线| 精品电影在线观看| 美女精品一区| 一区二区日本视频| 亚洲免费视频网站| 亚洲第一区在线观看| 欧美成人dvd在线视频| 欧美日韩爆操| 久久国产乱子精品免费女 | 亚洲电影第1页| 欧美日韩亚洲一区| 久久久久国色av免费看影院| 欧美a级片网站| 亚洲一区二区动漫| 久久这里有精品视频| 在线一区二区三区四区| 欧美在线在线| 亚洲一区二区av电影| 久久亚洲风情| 亚洲欧美国产77777| 久久综合伊人77777| 亚洲欧美一级二级三级| 美女啪啪无遮挡免费久久网站| 亚洲一区二区四区| 欧美.日韩.国产.一区.二区| 香蕉久久夜色精品国产| 欧美激情久久久| 久久综合网hezyo| 欧美视频在线一区| 欧美成人精品一区二区三区| 国产精品久久久久9999高清| 亚洲高清久久久| 黑人巨大精品欧美一区二区小视频| 欧美午夜女人视频在线| 欧美性片在线观看| 欧美国产日韩亚洲一区| 国产午夜一区二区三区| 亚洲人成亚洲人成在线观看| 经典三级久久| 欧美一区影院| 欧美一区二区三区免费观看| 欧美日韩午夜精品| 亚洲欧洲综合另类在线| 亚洲国产成人久久综合| 性高湖久久久久久久久| 午夜精品久久久久久久| 欧美日韩在线一区二区三区| 亚洲国产欧美日韩另类综合| 在线观看国产欧美| 久久久久久久尹人综合网亚洲 | 亚洲第一成人在线| 欧美伊人精品成人久久综合97 | 巨乳诱惑日韩免费av| 国产精品无码专区在线观看| 亚洲乱码一区二区| 99成人在线| 欧美日韩一区二区视频在线观看| 亚洲国产高清一区| 亚洲欧洲一区二区三区久久| 免费高清在线一区| 亚洲国产另类久久久精品极度| 亚洲精品影院| 欧美日韩视频在线一区二区 | 国产精品久久久久毛片大屁完整版 | 欧美第一黄色网| 亚洲高清在线| 欧美xxx在线观看| 亚洲人成欧美中文字幕| 亚洲精品久久久久久久久久久久久| 麻豆精品一区二区综合av| 欧美成人黑人xx视频免费观看| 亚洲国产高清aⅴ视频| 欧美a级理论片| 亚洲片国产一区一级在线观看| 中文欧美字幕免费| 国产精品一卡二卡| 久久久久一本一区二区青青蜜月| 久久综合色影院| 亚洲免费av电影| 国产精品一区二区女厕厕| 久久精品三级| 亚洲区国产区| 欧美一区二区在线看| 伊人蜜桃色噜噜激情综合| 欧美激情亚洲国产| 亚洲欧美中文日韩v在线观看| 噜噜噜91成人网| 亚洲天堂偷拍| 伊人久久久大香线蕉综合直播| 欧美激情亚洲自拍| 性久久久久久久| 亚洲欧洲日本在线| 性做久久久久久| 国产精品久久一区主播| 欧美制服第一页| 亚洲精品国产系列| 欧美综合国产| 99国产精品一区| 国产日韩欧美高清| 欧美精品1区2区| 欧美一区二区三区视频在线观看| 亚洲福利在线看| 久久中文字幕导航| 午夜精品亚洲| 中文成人激情娱乐网| 激情成人在线视频| 国产精品欧美日韩一区二区| 欧美成人网在线| 香蕉久久夜色精品| 亚洲麻豆一区| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲视频在线一区| 亚洲乱码日产精品bd| 在线观看视频亚洲| 亚洲欧美日韩人成在线播放| 欧美福利小视频| 麻豆亚洲精品| 久久久久国产一区二区三区| 亚洲一区二区在线| 99精品热视频| 亚洲精品在线观|