Catch up on stories from the past week (and beyond) at the Slashdot story archive

 



Forgot your password?
typodupeerror
×
Technology (Apple) Businesses Apple Technology

Apple OSes and IDE DMA Support? 49

KFox wishes to get to the core of this particular issue: "I just recently purchased an iBook and I have noticed that even in Jaguar, the system gets choppy from disk I/O. It appears that Mac OS 9 and Mac OS X don't support DMA access for hard drives, even if the drives are initialized in a UDMA mode. Wintel has had support in this area for a long time (since Win95b). Has anyone in the Mac world had any experience with DMA support on hard drives? Is it supported on iBooks? If so, which models?"
This discussion has been archived. No new comments can be posted.

Apple OSes and IDE DMA Support?

Comments Filter:
  • Drive Setup v1.1 (Score:4, Informative)

    by brejc8 ( 223089 ) on Monday September 09, 2002 @02:32PM (#4222272) Homepage Journal
    The ChangeLog [apple.com] seems to have added UDMA in version 1.1 and later updated in 1.7 .
    Try searching for UDMA Ultra-ATA ATA33/66/100 because DMA doesnt allways show up.

  • by TwP ( 149780 ) on Monday September 09, 2002 @02:35PM (#4222289) Homepage
    DISCLAIMER: I have not tried this, but I found a webiste that has ...

    Daemon News [daemonnews.org] has a little section on the iBook and DMA. You can see the Darwin boot sequence by holding down the "v" key at startup. Find the section titled "Further Exploration: Das Boot" in the article above and it will tell you how to view the boot messages and other useful tidbits.

    IOATAPICDDrive: Using DMA transfers

    IOCDDrive drive: MATSHITA, CD-ROM CR-175, rev 5AAE [ATAPI].
    IOATAHDDrive: Using DMA transfers
    IOHDDrive drive: , TOSHIBA MK3211MAT, rev J1.03 G [ATA].
    IOHDDrive media: 6354432 blocks, 512 bytes each, write-enabled.


    It appears that this revision-A iBook does indeed have DMA enabled for both the hard drive and the CD-ROM drive.

    This does not help you enable your own DMA, but do a search on Google for enabling DMA on FreeBSD style systems. You might find something useful.
    • Since 10.0 it is Command-V (V was the public beta). The information in the daemon news article is quite old. Jaguar seems a lot less verbose. It does not say anything about DMA transfers for disk or CD. Which of course doesn't mean it does not do DMA.
  • by Anonymous Coward on Monday September 09, 2002 @04:06PM (#4222630)
    Are you sure it's the disk causing the problem vs delays due to VM switching in and out. There's a memory utility (can't remember name, Memory Tracker or Memory Monitor?) that will beep each time memory is paged in or out (or you could use top if you can interpret the numbers).

    I've found it can be pretty easy to use up all free RAM if you have a number of programs open or they leak memory. I've found at times I've had over 2GB of switch files.

    This is with 896 MB of RAM, iBooks can be under spec'd in that department.
    • by Golias ( 176380 ) on Monday September 09, 2002 @04:16PM (#4222707)
      I thought the same thing as the AC when I saw this post. This sounds like more like a VM issue than a "lack of DMA" issue.

      I also recently bought an iBook, and the very first thing I did, before I even booted it up, was drop in a bunch more RAM (and my Airport card, while I was in there). I have not experienced the kind of sluggishness you are talking about during disk reads, so that might be what your actual problem is.

      OS X is the best OS experience I've ever had, but it is a memory pig. If you have the default RAM in your iBook (probably 128), you are hitting the VM a lot. It's fine if you don't mind a little sluggishness, but memory is cheap now days, so buying more is money well spent. Even another 128 can make a world of difference.

    • Try the command "vm_stat 1"; that'll print out VM statistics once a second, with the counts of various events (pages in/out, zerofills, etc.) given incrementally (and the grand totals every 25 lines or so).

  • Comment removed (Score:4, Informative)

    by account_deleted ( 4530225 ) on Monday September 09, 2002 @04:16PM (#4222704)
    Comment removed based on user account deletion
    • sysctl -a | grep dma

      Nope. sysctl is actually pretty small in Darwin. Mine has about 240 lines, 2/3rds of which are network-related (including 40 for IPv6). The only line related to my HD was vfs.hfs has 2 mounted instances

      • It's possible that the settings are hidden. Try "man ata" and see if it shows the settings like it does on freebsd, and then try setting them with sysctl.
    • OS X is based on FreeBSD, yes, but only its "BSD layer". The BSD layer controlls such things as file systems, networking, unixy apis used throuout the system, etc. The libraries and userland tools are based on NetBSD.

      Its driver interface is a homebrew system from Apple called "IOKit". IOKit is where you'd find the DMA stuff, but I don't know offhand how to access it. You may do well to try Apple's "Apple System Profiler".
  • by frankie ( 91710 ) on Monday September 09, 2002 @04:53PM (#4223080) Journal
    ...reveals that yes the iBook has DMA [google.com].

    Will someone please mod up comment #4222630 [slashdot.org]??? The most likely answer is KFox hasn't bought enough RAM.

  • This isn't the most comprehensive test of a disk's I/O, but it's easy and will help determine is something is potentially wrong.

    Run this command from the Mac OS X shell:

    dd if=/dev/zero of=testfile bs=1024 count=102400

    This should make you a 100 MB file. dd on some systems will give you how long it took to write out the file in seconds (I don't have access to a Mac OS X box, just a FreeBSD box right now). If it doesn't, just put the time command in front of it:

    time dd if=/dev/zero of=testfile bs=1024 count=102400

    Devide the number of seconds it took to write the file out by 100, and you'll have a rough estimate of how many megabytes per second it wrote to disk.

    Again, not the most comprehensive metric of course, but it gives you a rough idea. For an ATA system, it should probably do between 15 and 25 MB/s without too much trouble for a fast drive. The interface can be much faster (ATA/33, ATA/66, ATA/100), but the UFS and HFS+ file systems aren't optimized for sequntial writing, and/or there are other factors involved, so about 20 MB/s is a good mark I think.

  • My iMac certainly feels slow, but I don't think it's disk DMA. "dd bs=8k count=100000 >ttt /dev/zero" gives a speed of 30MB/s which would be impossible without DMA.

    Anyone know a way to check whether ATA write caching is enabled? The FreeBSD ATA sysctls don't work, presumably it's not using the FreeBSD ATA drivers.
  • Not a DMA issue (Score:3, Informative)

    by h0tblack ( 575548 ) on Monday September 09, 2002 @07:33PM (#4224297)
    Mac's have had DMA support for a long time in both hardware and software, see this technote [apple.com] and the Developer Notes on hardware here [apple.com] for details. This includes the original clamshell [apple.com] iBooks. The iBooks may not have the fastest drives or interfaces but I don't think this is the problem. It's much more likely a Virtual Memory issue with lots of caching going on. check the contents of /private/var/vm/ for the number of 80Mb swapfiles you have, also try issuing vm_stat from the CLI to see whats going on. Two suggestions, either get more RAM or setup a 'clean' swap-drive partition.
    • As I recall, DMA support in the Mac goes all the way back to the IIfx (a sweet machine), but it either was never used by the system or was hobbled in some way. Not sure. Can someone fill in the blanks?
  • The linux IDE driver has an option which controls whether it masks or unmasks non-ide interrupts during disk transfers...this option makes a huge difference in the amount of cpu time disk access consumes.

    Does OS X have something similar?
  • DMA isn't the problem, OS X is the problem. The iBook, even with 512 MB of RAM, is just slow. Live with it I guess... and everyone considering one of these machines should try before they buy.

    I was just at CompUSA playing with the new dual Macs with Jaguar, and even they lag quite frequently, especially with web browsers.

    • I have a 550 PowerBook, and I loved it when I first got it, and to be honest, I don't think I ever noticed how laggy OSX was. Now with Quartz Extreme, things just respond, and move quickly. In fact, things started moving so well, that I dumped Mozilla, because it's interface was lagging (because of the XUL defined interface)

      Doing everything with PDF actually is a very good idea, and I'm glad that they have it hardware accelerated now. Scaling is much faster now, and everything.

      But, as someone else pointed out. Linux, and X still seems to run faster, which is pretty ridiculous, considering that X is running through a socket, and is naturally indirect. *sigh*

      Still, Apple's idea is to advance what you can do with a GUI, and I think this is a positive push forward, and I want to see Apple make things even better!
      • But, as someone else pointed out. Linux, and X still seems to run faster, which is pretty ridiculous, considering that X is running through a socket, and is naturally indirect. *sigh*

        I'm not sure of the technical details, but my understanding is that Quartz works very much the same way - although Apple doesn't seem to provide a way to do it, it should be possible to run applications remotely, just like you can with X.
      • But, as someone else pointed out. Linux, and X still seems to run faster, which is pretty ridiculous, considering that X is running through a socket, and is naturally indirect. *sigh*

        If you're on the console it better NOT be. Local X traffic should be going through shared memory queues and not the networking layer. Many of the common unix workstations were doing this at least 10 years ago. I would certainly would have thought the XFree team would have implemented it.

  • I too had bad problems with disk lag on my iMac rev. A. The two things I did to increase the speed of drive I/O to the very acceptable latency was;
    1: 7200rpm drive (this helped the most) and
    2: More ram as others have mentioned, this does work (320mb instead of 192mb).

    A couple of my friends have also done dedicated swap partitions and gotten even more responciveness. Other's here have also suggested this.

    R
  • Every PCI Powermac with IDE i.e. the 6400/ 6360 and later has been able to do DMA and uses DMA if the drive supports it. You can't disable DMA if it is enabled and you are using the MacOS. Granted until the Blue & White G3 the kind of DMA used is Multiword DMA. Any of the problems you may have heard about Multiword DMA are only compatability problems in Win 95. Multiword DMA works perfectly fine in the MacOS.

"If it ain't broke, don't fix it." - Bert Lantz

Working...