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

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) 評論(0)  編輯 收藏 引用 所屬分類: OS
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(10)

隨筆分類(307)

隨筆檔案(297)

algorithm

Books_Free_Online

C++

database

Linux

Linux shell

linux socket

misce

  • cloudward
  • 感覺這個博客還是不錯,雖然做的東西和我不大相關,覺得看看還是有好處的

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

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产欧美日韩一级| 在线视频欧美日韩| 日韩视频精品在线| 亚洲国产高清在线| 亚洲福利小视频| 91久久精品一区二区三区| 亚洲黄色免费电影| 日韩视频中文字幕| 亚洲女人天堂av| 欧美自拍偷拍| 欧美福利网址| 99精品黄色片免费大全| 亚洲天堂第二页| 久久精品国产一区二区三| 你懂的一区二区| 欧美日本国产视频| 国产精品日韩专区| 亚洲第一区中文99精品| 一区二区三区国产精品| 久久激情婷婷| 亚洲黄网站黄| 亚洲精品乱码久久久久久黑人 | 欧美一级视频精品观看| 久久精品动漫| 亚洲国产小视频在线观看| 一区二区三区国产在线观看| 先锋影音一区二区三区| 欧美成人综合在线| 国产日产亚洲精品| 99精品视频一区| 另类尿喷潮videofree| 99精品热视频| 久久综合999| 国产伦精品一区二区三区照片91 | 狼人社综合社区| 欧美性理论片在线观看片免费| 国内精品国产成人| 亚洲一区二区三区在线看| 欧美 日韩 国产在线| aa亚洲婷婷| 男人的天堂亚洲| 极品少妇一区二区三区精品视频| 亚洲国产精品久久久| 亚洲视频免费看| 欧美成人精品在线视频| 国产一区二区三区在线观看网站| 日韩香蕉视频| 欧美黄色aa电影| 欧美亚洲日本网站| 国产精品久久综合| 亚洲视频免费观看| 亚洲精品国产日韩| 欧美jizz19hd性欧美| 今天的高清视频免费播放成人| 午夜欧美大片免费观看| 一区二区国产在线观看| 欧美日韩视频在线一区二区观看视频 | 久久久久久伊人| 亚洲永久免费av| 欧美色网在线| 亚洲综合不卡| 一区二区三区 在线观看视| 欧美精品在线免费观看| 亚洲乱码国产乱码精品精| 欧美成人一区二区三区在线观看| 欧美一区二区三区啪啪| 亚洲精品视频在线观看网站| 亚洲精品视频免费观看| 久久久久国色av免费观看性色| 国产精品私人影院| 翔田千里一区二区| 亚洲一区在线播放| 国产精品99久久久久久久久 | 亚洲第一网站| 国产精品久久亚洲7777| 久久久天天操| 国产欧美日韩精品在线| 欧美中文在线观看| 欧美一区二区三区视频在线| 国产精品青草综合久久久久99| 亚洲综合日本| 欧美一区视频在线| 亚洲福利视频一区二区| 亚洲精品字幕| 国产精品欧美在线| 久久久久免费| 欧美1区视频| 亚洲一区二区黄色| 欧美伊人久久久久久午夜久久久久 | 国产精品专区h在线观看| 香蕉久久精品日日躁夜夜躁| 香蕉久久夜色精品| 亚洲国产99| 一区二区国产日产| 一区精品在线播放| 99精品国产高清一区二区| 国产日韩高清一区二区三区在线| 久久中文在线| 欧美午夜激情小视频| 久久一二三国产| 欧美视频在线一区二区三区| 久久免费观看视频| 欧美日韩免费高清一区色橹橹| 欧美在线观看视频| 欧美黄色一区| 麻豆国产精品va在线观看不卡| 欧美一区二区播放| 亚洲精品男同| 午夜精品亚洲| 99re热这里只有精品视频| 亚洲欧美日韩另类| 99精品国产一区二区青青牛奶| 午夜精品久久久久久久| 亚洲乱码国产乱码精品精天堂| 亚洲一区二区在线| 欧美性淫爽ww久久久久无| 久久先锋资源| 亚洲欧洲99久久| 激情久久五月| 亚洲午夜未删减在线观看| 亚洲激情第一区| 亚洲在线视频观看| 一道本一区二区| 久久婷婷国产麻豆91天堂| 午夜在线成人av| 欧美国产先锋| 免播放器亚洲| 国产在线精品自拍| 香蕉免费一区二区三区在线观看| 亚洲激情啪啪| 欧美制服丝袜第一页| 亚洲欧美日韩一区二区在线| 欧美国产先锋| 亚洲日韩欧美视频| 亚洲精品欧美| 欧美国产高清| 亚洲三级视频| 一区二区三区四区五区视频| 免费成人高清在线视频| 欧美国产日韩精品| 亚洲精品综合久久中文字幕| 美女精品在线观看| 亚洲成色精品| 99天天综合性| 欧美日韩中文字幕在线| 亚洲美女在线国产| 亚洲视频一二三| 欧美性一二三区| 亚洲一线二线三线久久久| 午夜一区二区三区在线观看| 国产日韩欧美一区二区三区四区| 亚洲在线播放电影| 久久亚洲精品一区二区| 亚洲承认在线| 欧美片在线观看| 亚洲影视综合| 免费成年人欧美视频| 亚洲国产视频直播| 欧美日韩国产成人在线| 中文av字幕一区| 久久先锋影音av| 9色精品在线| 国产精品一区毛片| 久久久久一区二区三区| 亚洲国内自拍| 销魂美女一区二区三区视频在线| 国产丝袜一区二区| 免费成人你懂的| 一区二区三区.www| 久久综合999| 中文精品视频| 黄色成人av| 欧美无乱码久久久免费午夜一区| 亚洲欧美国产制服动漫| 久久久精品一区| 一区二区三区久久久| 国产亚洲一本大道中文在线| 欧美成人免费va影院高清| 亚洲午夜91| 欧美激情在线免费观看| 先锋影音久久久| 亚洲国产日韩欧美| 久久国产精品第一页| 久久亚洲精品一区| 一本大道av伊人久久综合| 国产精品腿扒开做爽爽爽挤奶网站| 久久久7777| 免费在线成人| 欧美亚洲三级| 宅男精品视频| 亚洲人成在线观看一区二区| 久久精品国产77777蜜臀| 一区二区三区 在线观看视| 伊人蜜桃色噜噜激情综合| 欧美午夜精品久久久久久浪潮 | 影音国产精品| 国产欧美综合在线| 国产精品久久看| 欧美日韩国产成人在线观看| 麻豆精品视频在线观看视频|