Login
Username:

Password:

Remember me



Lost Password?

Register now!

Sections

Who's Online
38 user(s) are online (16 user(s) are browsing Forums)

Members: 0
Guests: 38

more...

Support us!

Headlines

 
  Register To Post  

What happened to IExec->StartDMA()...?
Quite a regular
Quite a regular


See User information
Hi everybody,

Had another quick go at TV card drivers under the final update and they no longer work at all....

IExec->StartDMA() now returns NULL so it's not starting the DMA properly. I suspect this is because the address I'm trying to start the DMA at looks suspiciously virtual (it was allocated MEMF_PUBLIC | MEMF_HWALIGNED I think it was). It always worked before but I seem to recall AllocMem() is no longer guaranteed to return a physical address, even in MEMF_PUBLIC.

Just for the heck of it I tried IMMU->GetPhysicalAddress() on the address that was allocated but this call just calls the Grim Reaper.

Does anyone have an example of how to use DMA (or interrupts for that matter though I may be ok on that) under the final update? Are there any open source DMA-capable drivers?

Thanks!


--
Ian Gledhill
ian.gledhill@btinternit.com (except it should be internEt of course...!)
Check out my company's shop: http://www.mutant-caterpillar.co.uk/shop/ - specialising in Sinclair Spectrums but will be adding Amigas!
Go to top
Re: What happened to IExec->StartDMA()...?
Just popping in
Just popping in


See User information
@Spirantho

Have you locked the memory with Exec/LockMem()?

I you are aware of the fact that Exec/StartDMA() does not return a pointer, but a number of the DMA block lists, which must be allocated for the process.

Go to top
Re: What happened to IExec->StartDMA()...?
Quite a regular
Quite a regular


See User information
@rachy

This is a small part of the output of my program:

[CODE]
Starting DMA at 0x0x66624000, size=442368, flags = 0.
Can't start DMA transfer.
[/CODE]

It's fairly self-explanatory. :)

I just tried calling IExec->LockMem on the address, no difference.
But that address looks rather virtual to me, which I imagine may be no good for DMAing....

And yes, I am aware of that fact. :) The code works fine under Update 4. It currently returns NULL though.

All I need is to tell the Amiga that this block of memory is to be DMA'ed to by the TV card.

Go to top
Re: What happened to IExec->StartDMA()...?
Amigans Defender
Amigans Defender


See User information
@Spirantho

i tried to run amitv today instant lock up here now i know why

Amiga is the heart and soul of computing nothing else comes close
Go to top
Re: What happened to IExec->StartDMA()...?
Just popping in
Just popping in


See User information
@Spirantho

I'd be glad to help ; I'd have thought that the exec autodocs for startdma/getdmalist/enddma are rather well written (no, i did not write them :)

Can you please paste here your code :

- which allocates the dma buffer

- which is between startdma and enddma

Regards,
--
St?phane

Go to top
Re: What happened to IExec->StartDMA()...?
Quite a regular
Quite a regular


See User information
@sg2

Quote:

sg2 wrote:
I'd be glad to help ; I'd have thought that the exec autodocs for startdma/getdmalist/enddma are rather well written (no, i did not write them :)

Can you please paste here your code :

- which allocates the dma buffer

- which is between startdma and enddma


They were written well but I think a little out of date now. :)

I'm away from my code ATM but...
The code which allocates the buffer is just a standard
IExec->AllocMem( size, MEMF_PUBLIC | MEMF_HWALIGNED) I think.
As for what happens between the StartDMA and the EndDMA I can't remember, pretty much the same as the autodoc! However as StartDMA is returning NULL it doesn't get that far anyway! It's the StartDMA itself which is broken....

--
Ian Gledhill
ian.gledhill@btinternit.com (except it should be internEt of course...!)
Check out my company's shop: http://www.mutant-caterpillar.co.uk/shop/ - specialising in Sinclair Spectrums but will be adding Amigas!
Go to top
Re: What happened to IExec->StartDMA()...?
Just popping in
Just popping in


See User information
@Spirantho

I'd like you to paste (or send me) the complete code.

I also have access to the kernel cvs so i can investigate in the kernel source if necessary.

Regards,
--
St?phane

Go to top
Re: What happened to IExec->StartDMA()...?
Quite a regular
Quite a regular


See User information
@sg2

Which bit exactly do you need?
I can send you the bit where I call StartDMA() and the allocation... if you really want it I can send you the bit after StartDMA too but there doesn't seem much point as it's never called (StartDMA returning NULL of course)...

mDisplayBitmap IP96->p96AllocBitMapprefs->Widthprefs->Height320NULLRGBFB_B8G8R8A8 );
    
mFrameBuffer = (unsigned char *)IExec->AllocVecprefs->Width prefs->Height 4MEMF_PUBLIC MEMF_HWALIGNED );

    
printf"Getting physical address of frame buffer.\n" );

//    APTR tStack = IExec->SuperState();
//    mFrameBufferPhysical = (unsigned char *)IExec->Supervisor(IMMU->GetPhysicalAddress( mFrameBuffer ));
//    IExec->UserState( tStack );

    
mFrameBufferPhysical mFrameBuffer;

    
IExec->LockMemmFrameBufferprefs->Width prefs->Height );

    
printf("Frame buffer is at 0x%p.\n"mFrameBufferPhysical );


The bit about the FrameBufferPhysical is where I was trying to get the physical address. I didn't need to do that before. Also of course I didn't need to worry about going into Supervisor state or anything before.
Also the LockMem() wasn't there before, I just put that in to see what would happen after it was suggested above.

void Console::StartDMAList()
{
    
int tResult;
    
printf"Starting DMA at 0x%p, size=%d, flags = %d.\n", (ULONG)mFrameBufferPhysicalmPrefs->Width mPrefs->Height *4);
    
tResult IExec->StartDMAmFrameBufferPhysicalmPrefs->Width mPrefs->Height 4);
    if ( 
tResult )
    {
        
mDMAList = (struct DMAEntry *)IExec->AllocVectResult sizeofDMAEntry ), MEMF_ANY );
        if ( 
mDMAList )
        {
            
IExec->GetDMAListmFrameBuffermPrefs->Width mPrefs->Height 40mDMAList );
        }
        else
        {
            
printf"Can't allocate DMA list.\n" );
        }
    }
    else
    {
        
printf"Can't start DMA transfer.\n");
    }
}


This code probably looks very familiar if you wrote the autodoc. :) tResult is set to 0 of course, signifying the DMA failing to start.

Help? :)

--
Ian Gledhill
ian.gledhill@btinternit.com (except it should be internEt of course...!)
Check out my company's shop: http://www.mutant-caterpillar.co.uk/shop/ - specialising in Sinclair Spectrums but will be adding Amigas!
Go to top
Re: What happened to IExec->StartDMA()...?
Just popping in
Just popping in


See User information
@Spirantho

Did you check the return of allocvec ?

By the way there's no reason why you'd need memf_public, you should rather use the new allocvectags, and ask for contiguous memory, with proper alignment.

Also, while it may sound wise to lockmem, its not necessary until the pager is running.

Finally, you don't have to get the physical address of your buffer, startdma takes a virtual address, and getdmalist will return the physical mappings of your buffer.

Note, given that allocvec can return scattered pages, if your DMA hardware does not support scatter/gather, then you HAVE to use allocvectags and explicitly ask for a contiguous buffer.

Regards,
--
St?phane

Go to top
Re: What happened to IExec->StartDMA()...?
Quite a regular
Quite a regular


See User information
@sg2

That's the second time someone's mentioned a function called AllocVecTags (or AllocVecTagList)...

I'm using the SDK on the Hyperion FTP site, v51.22... I'm starting to suspect there's a newer version which I don't have but without which I can't do anything... am I correct?

--
Ian Gledhill
ian.gledhill@btinternit.com (except it should be internEt of course...!)
Check out my company's shop: http://www.mutant-caterpillar.co.uk/shop/ - specialising in Sinclair Spectrums but will be adding Amigas!
Go to top
Re: What happened to IExec->StartDMA()...?
Just popping in
Just popping in


See User information
@Spirantho

Well, I don't know, as I'm not using the SDK (but rather, compiling directly within the OS cvs).

But if you don't have access to that function (or if its not documented in exec.doc) then indeed I'm afraid you'll have to wait for a new SDK.

BTW you did not tell me the return of allocvec.

Regards,
--
St?phane

Go to top
Re: What happened to IExec->StartDMA()...?
Amigans Defender
Amigans Defender


See User information
@Spirantho
The AllocVecTags() function and other changes will be made available in the updated SDK.

@sg2
Are you sure you can do DMA drivers without the updated SDK on the new kernel?

ExecSG Team Lead
Go to top
Re: What happened to IExec->StartDMA()...?
Quite a regular
Quite a regular


See User information
@ssolie

Quote:

ssolie wrote:
@Spirantho
The AllocVecTags() function and other changes will be made available in the updated SDK.

@sg2
Are you sure you can do DMA drivers without the updated SDK on the new kernel?


Looks like that's what it needs. Kind of annoying really... spend ages waiting for overlay code and now I've got it I can't compile even a normal version yet. Hope the SDK doesn't take too long!

@sg2
The AllocVec returns the number I put in the debug output at the top.

--
Ian Gledhill
ian.gledhill@btinternit.com (except it should be internEt of course...!)
Check out my company's shop: http://www.mutant-caterpillar.co.uk/shop/ - specialising in Sinclair Spectrums but will be adding Amigas!
Go to top
Re: What happened to IExec->StartDMA()...?
Just popping in
Just popping in


See User information
@ssolie

indeed, we have abandoned memf_public as a safe way to allocate contiguous / physical=virtual buffers, in favor of a more flexible api but this obviously requires the new sdk...

Regards,
--
St?phane

Go to top
Re: What happened to IExec->StartDMA()...?
Amigans Defender
Amigans Defender


See User information
@Spirantho
Quote:
Hope the SDK doesn't take too long!

You could try and contact Hyperion to get access to the beta SDK as a 3rd party developer if you don't want to wait.

ExecSG Team Lead
Go to top
Re: What happened to IExec->StartDMA()...?
Just can't stay away
Just can't stay away


See User information
@ssolie

Quote:
Are you sure you can do DMA drivers without the updated SDK on the new kernel?

For hardware which supports scatter/gather DMA: Yes.

For hardware which doesn't but needs contiguous physical memory for DMA you need AllocVecTags() now and need the new SDK, up to Update4 you could use a MEMF_PUBLIC buffer instead.

Go to top
Re: What happened to IExec->StartDMA()...?
Just popping in
Just popping in


See User information
@Spirantho

IIRC it must be MEMF_SHARED | MEMF_HWALIGNED but I could be wrong because I never had the honour to write a DMAable driver. For GetPhysicalAddress() and friends you need to switch to Supervisor() mode, first.

AmigaOS4 developer
Go to top
Re: What happened to IExec->StartDMA()...?
Just popping in
Just popping in


See User information
@srupprecht

memf_public is not the way.

He has to wait for a new sdk with allocvectags.

Plus he does not need getphysicaladdress, the prd's returned by getdmalist are all he needs to set his dma hardware. If his hardware does not support scatter/gather then he has to allocate his buffer using the contiguous tag of allocvectags.

If he wants to cache flush the buffer, he needs a 32 byte aligned buffer at both ends to avoid side effects of ppc cache flushes.


Regards,
--
St?phane

Go to top

  Register To Post

 




Currently Active Users Viewing This Thread: 1 ( 0 members and 1 Anonymous Users )




Powered by XOOPS 2.0 © 2001-2024 The XOOPS Project