Swapping doesn't work with update 4.

A forum for AmigaOne XE and MicroA1-C specific issues.
Deniil
Posts: 109
Joined: Mon Jul 11, 2011 6:59 pm

Swapping doesn't work with update 4.

Post by Deniil »

1. Unpack the test tool (source also included).
2. Boot without startup-sequence.
3. Start the test tool.
4. Hit Ctrl-D to allocate memory until it runs out.
5. Hit Ctrl-D once more to make it swap.
6. Hit Ctrl-F until all memory has been freed.
7. Repeat step 4 and 5 once.
8. The machine locks up hard at step 5 so the reset button is the only choice.

This is repeatable for me every time.
If you quit the test tool after step 6, then redo the procedure, steps 3-6 it may take a few more runs until it locks up.

I have 512MB and one block (they are 20MB) "too much" is enough to repeat this. If you have a lot more memory, perhaps you need to make it swap out a little more to repeat this.

My SWAP: is 2GB and located at around 100GB on a 120GB IDE disk connected to a SII0680 in an A1-XE/G4.

Please acknowledge and try to fix this!

Any X1000/update5 users: Is this repeatable for you? Gues you need less than 2GB physical RAM to make use of the swap perhaps.
User avatar
tingo
Beta Tester
Beta Tester
Posts: 191
Joined: Mon Dec 20, 2010 1:52 pm
Location: Oslo, Norway

Re: Swapping doesn't work with update 4.

Post by tingo »

I guess most (all?) X1000 owners doesn't have SWAP: setup at all. The recommendation is that swap isn't needed if you have 2GB (or more) memory.
Torfinn
User avatar
Raziel
Posts: 1170
Joined: Sat Jun 18, 2011 4:00 pm
Location: a dying planet

Re: Swapping doesn't work with update 4.

Post by Raziel »

@Deniil

Affirmative.

OS4upd4
AOneXE - 1GB RAM - 1GB SWAP

Following your steps it locks up hard at #5 with it being able to print "Allocation block xx" but after that nothing, complete halt
People are dying.
Entire ecosystems are collapsing.
We are in the beginning of a mass extinction.
And all you can talk about is money and fairytales of eternal economic growth.
How dare you!
– Greta Thunberg
Deniil
Posts: 109
Joined: Mon Jul 11, 2011 6:59 pm

Re: Swapping doesn't work with update 4.

Post by Deniil »

@Raziel

Thanks!
Now, any beta tester, or even developer (:-o !!!) willing to risk their reputation by repeating this very very simple test case in a 100% controlled situation/environment causing a pretty certain lockup? ;-) Remember that the source code is included so you can verify that the code is not at fault.

It seems something goes wrong when swapped out (virtual) memory is freeded and then reused, which was also my suspicion in daily use, since the lockup usually didn't occur until I quit a program having swapped and then tried to uniconify another program, presumably being swapped out.
User avatar
tonyw
AmigaOS Core Developer
AmigaOS Core Developer
Posts: 1479
Joined: Wed Mar 09, 2011 1:36 pm
Location: Sydney, Australia

Re: Swapping doesn't work with update 4.

Post by tonyw »

I tried it on my A1-XE with 512 MB RAM and >2 GB swap partition. My beta test installation is a bit later than Update 4 but the kernel is unchanged in the memory alloc and swapping functions AFAIK.

Mixed results: sometimes it locks up as you say, sometimes it runs fine over and over again.

It's late now, but I'll have a look at your test proggie tomorrow, on the other machines as well.
Thank you for going to all this trouble to isolate a problem. Let's hope we can get it sorted.

BTW, why do you use obsolete system calls like AllocMem() and FreeMem() ?
cheers
tony
Deniil
Posts: 109
Joined: Mon Jul 11, 2011 6:59 pm

Re: Swapping doesn't work with update 4.

Post by Deniil »

@tonyw

Thanks for taking an interest in this. Reboots because of swapping lockups is currently my main reason for reboots. Now that I got your attention I'll disable swapping for now since it simply doesn't work.

I wonder why it doesn't lockup everytime for you, if you followed the step without exiting the test tool in between. Could it have something to do with disk timing? I have a 120GB PATA disk on the second channel of a sii0680 and the SWAP is located far out on the disk, at 100GB, and it's slightly less than 2GB IIRC.

Btw. I though AllocMem was still the primary and most basic way of allocating memory. What's the alternative? AllocSysObject and a heap of tags? No thanks, unless I would need one of the new special features. It's also not portable, and I typically write a lot of portable code.
amigaonefan
Posts: 43
Joined: Fri Sep 16, 2011 9:20 pm

Re: Swapping doesn't work with update 4.

Post by amigaonefan »

Okay, can someone remind me again exactly how to disable swapping in Os4.1?

Thanks
User avatar
davebraco
Beta Tester
Beta Tester
Posts: 140
Joined: Sat Jun 18, 2011 7:06 am
Location: Belgium

Re: Swapping doesn't work with update 4.

Post by davebraco »

Disable the swap in media-toolbox by unchecking the automount button for this partition.
µA1 256mo SATA -> lend to a dev
A1200PPC 256Mo MediatorTX Radeon9250 SATA RTL8029 SOLO-1
Sam440ep 533mhz 512mo 64Go SSD
Sam460ex 1150mhz 2Go RadeonHD 6570LP ENVY24HT
AmigaOne X1000 4Go SSD R9 270X Catweasel MK4
AmigaOne X5000 -> work in progress
User avatar
Thomas Frieden
AmigaOS Core Developer
AmigaOS Core Developer
Posts: 147
Joined: Fri Dec 10, 2010 3:21 pm

Re: Swapping doesn't work with update 4.

Post by Thomas Frieden »

Question: Did it work prior to Update 4 ?
User avatar
Thomas Frieden
AmigaOS Core Developer
AmigaOS Core Developer
Posts: 147
Joined: Fri Dec 10, 2010 3:21 pm

Re: Swapping doesn't work with update 4.

Post by Thomas Frieden »

Deniil wrote:Now, any beta tester, or even developer (:-o !!!) willing to risk their reputation by repeating this very very simple test case in a 100% controlled situation/environment causing a pretty certain lockup? ;-) Remember that the source code is included so you can verify that the code is not at fault.
What does that have to do with reputation ? If there's a bug, and someone can deliver a test case that shows it, then I'll gladly acknowledge that I made a mistake and can correct it.
Deniil wrote:It seems something goes wrong when swapped out (virtual) memory is freeded and then reused, which was also my suspicion in daily use, since the lockup usually didn't occur until I quit a program having swapped and then tried to uniconify another program, presumably being swapped out.
It's not that simple. I tried it, and it didn't lock up at first... I repeated the allocation->deallocation cycle several times, until it finally locked up. It's not as simple as re-allocating something that has been paged out before. It might also be a race condition. I will have to find out what exactly is happening to be sure.

Question still stands, did it happen on anything prior to Update 4 ?
Post Reply