DX11 error : CreateTexture failed : E_OUTOFMEMORY

  1. ‹ Older
  2. 8 years ago

    There is an excellent technet article covering this stuff:

    https://blogs.technet.microsoft.com/markrussinovich/2008/11/17/pushing-the-limits-of-windows-virtual-memory/

  3. Friznit

    7 Dec 2016 Administrator

    Try a different malloc maybe? Dwarden keeps banging on about it anyway.

  4. The default malloc in 1.66, tbb4i or whatever, is pretty much the best available malloc already. I forgot when that change was made (fairly recent IIRC) but I think trying different mallocs is slightly outdated.

  5. Dwarden confirmed as much recently. Last I read it's not advised to use any malloc but BIS's.

  6. @nateberkopec Committed memory != virtual memory in Windows. Virtual memory has addresses, that's the entire point of virtual memory - to create the address space.

    Task Manager in Windows Server 2012 and Windows 8 :
    Committed Committed memory is the physical memory in use for which space has been reserved in the paging file should it need to be written to disk.

    “Not true - if you have no paging file you still have committed memory - committed virtual memory is private, nonshareable virtual memory created by processes or the OS or drives that MAY need to be paged out. This always starts out in RAM and *may* get paged out if necessary. So committed memory can be backed by RAM (and if you have no paging file, it remains in RAM until the VM is deleted such as at process exit).

    Even if you have a paging file, space is not reserved for this until such time as it actually DOES get paged out. What Windows *does* make sure is that it doesn’t overcommit meaning private virtual memory allocations are charged against the commit LIMIT (sum of RAM + paging files though the current commit limit shown in Task Manager or other tools is based on the CURRENT size of the paging file, meaning if paging files are configured to expand [the default when you choose System Managed] that the commit limit will go up as the paging file expands).”

    Breaking the 32 bit Barrier :
    on game initialization, enough memory is reserved and committed by using CreateFileMapping API. This consumes the physical memory, but no virtual addresses

    ...

    Windows is handling this pattern very well, while the space can be backed up by the "page file" in theory, in practice it works in such a way that as long as there is enough of physical memory available, there is zero page file traffic and all information is handled in the physical memory only. The memory kept in this type of storage is not mapped to any virtual addresses at all, it is identified by the offset in the file mapping instead. Addresses are assigned only temporarily, when the content of the cache is read.

    But, whatever. I'm done.

  7. It's simple to me...before 1.66 I was able to have draw distances over 10,000 and frequently when I have been working as the GM in Zeus I had it at the max which I think was 20,000 when using ALiVE. However after that version dropped my draw distance can not exceed 5000 when using ALiVE. When I do go over that I get a straight kick in the balls and the game crashes and says it is out of memory. So for me I keep it down around 5k on the draw distance and to hell with everything else.

    I do believe there is some aspect of the whole SSD as your drive that houses A3 that might have some validity but I am just an old school gamer who really doesn't like understanding some of this technical mumbo jumbo crap.

  8. New performance binary increases maxmem (maximum memory in physical RAM) from 2GB to 3GB.

    I don't think it will fix this crash (since we were running out of virtual address space), but might be worth a shot. In the worst case it should be an overall faster build :)

  9. Another thing, which may have a bigger effect on this crash - there's a Reddit thread right now that alleges that the maxVRAM parameter is broken and doesnt get set correctly.

    All of our RPT files run out of memory allocating textures in DirectX, which is sort of weird because I would think textures go straight to VRAM rather than ever living in system memory. Perhaps ARMA thinks it's out of video memory and is using system memory to compensate? I don't really know anything about video memory, I suspect it's all taken care of by the card driver.

    Anyway, people having this exact problem (running out of virtual memory during DirectX createTexture) may try setting maxVRAM in the ARMA launcher to the exact value of their video card.

  10. 7 years ago

    Something I read on a mission thread today, could be completely unrelated:

    Crash Issue: "I and other users connecting to the mission keep getting a memory crash error!"
    Temporary Workaround: For now, the only way around this is to set verifySignatures=2 on your dedicated server and perhaps also disable BattlEye.  The actual cause of the memory crashes are unknown.  It seems to occur sometimes when CUP Weapons, Units, and Vehicles are loaded.

  11. @SpyderBlack723 Link? Anyone post a RPT file? I'll bet that's an access violation crash, not an out-of-memory crash.

    In any case, 64-bit hit dev branch today which *will* fix the particular crash in this thread permanently (since virtual memory will no longer be limited to 4GB, which is what caused this crash). From what I heard ALiVE doesn't work with it yet, though.

  12. Edited 7 years ago by HeroesandvillainsOS

    @nateberkopec From what I heard ALiVE doesn't work with it yet, though.

    Is that true???

    If so, does that mean every single mod ever will need to be ported to work with 64-bit???

    I mean, I guess that makes sense seeing as most mods needed ports with Skyrim SE but damn if that's not a real buzzkill. My @mods has to be dozens of GB's. To have to redownload everything again? Wow.

    EDIT: Apparently ALiVE will not work with 64-bit right now according to Road Runner. Bummer. As if you guys aren't busy enough as it is. :(

  13. Why wouldn't ALiVE work? The only things affected by the 64-bit switch are the DLLs. ALiVEClient.dll is only used for indexing maps and ALiVEPlugin.dll is only used for persistence on the server. Just keep using the 32-bit server and everything will work fine besides indexing.

  14. For modders, too, there are some things to keep in mind. If your scenario or mod uses a call extension, the extension has be to provided both in 32-bit and 64-bit versions now. Otherwise, your game will most likely not work as expected. Unfortunately, there is no flexible way for us to work this around for you behind the scenes. 64-bit processes can only load 64-bit shared libraries (*.dll on Windows, *.so on Linux) and therefore it is expected that content creators provide them. This process should be rather straightforward, though, and we do not expect any major complication on our talented community's side.

    To make the transition as transparent for you as possible, we at least made it so that no changes to scripts will be required. All you need to do is build a 64-bit version of your extension and name it <yourExtension>_x64.dll on Windows (or <yourExtension>_x64.so on Linux). In other words, you add the "_x64" suffix to the name. Similarly, mod creators relying on hacking repurposing DirectX libraries will have to dust off their skills once again and perform their magic on 64-bit version of these libraries in similar a fashion as they did on their 32-bit counterparts back in the day. Of course, it is also worth mentioning that you should not forget to whitelist your new libraries with BattlEye!

  15. I ordered 32 gigs of 2400 DDR3 corsair dominator platinum ram(still running on sandy bridge architecture till the next hot gaming CPU comes out....if ever). This is not the first upgrade I have made simply for Arma 3 lol. Now we will see if more ram actually helps or the if the game is limited by design! Thanks for all the great posts everyone!

  16. I'm running a i5 6600K with 16gigs ddr4 ram and a gtx 1070 and I too am getting this error, but only when using the Alive mod. Vanilla Arma or exile I'm ok. I love this mod I feel it brings so much to a Multiplayer experience

  17. Tupolov

    12 Jan 2017 Administrator

    Arma 3 32 bit will now use up to 3GB of memory.

    Arma 3 64 bit will now use up to 8GB of memory.

    We're all hoping BIS unlock the memory use so Arma 64 bit can use more than 8GB.

    To understand why you are getting OUT_OF_MEMORY crash with ALiVE, its good to know how many AI/profiles you have in mission and how long the mission has been running.

  18. Where can I limit the AI profiles? Active Limiter? if so I set that to 45 and the CIV to 20 to allow for overages in AI Spawned. On maps like Fallujah and Kunduz with large open areas and few building the game runs smooth, but Altis, Tanoa forget about it. with mods like exile I have no issues, but exile is dying like DayZ the Developer stopped Development and its only a matter of time before Arma updates and break exile for good.

  19. You're actually doing this backwards. From the wiki:

    Making a mission with a lot of Virtual AI then artificially spawn-limiting them is inefficient and may get weird results, such as units spawning in behind players and moving into areas already cleared. Best practice is to reduce the density or number of Virtual Profiles in the Placement Modules to improve performance.

    So what I like to do, is keep the Virtual AI profiles as close the default 144 as possible, and limit the actual spawns with the mil/civ objective modules themselves.

  20. I'm completely new at all this, I'm coming from exile mission making. In the mil and civ placement modules. We're the override units like armor and infantry placing 3 or 4 controls the amount of units placed or the drop downs company, platoon? Because I'm running overrides of 2,2,2,1,0 with platoon size of 60 in each I've tried it at no overrides and battalion of 800 and the FPS and crashes still happen. Even at the lowest settings they still happen. It's very frustrating.

  21. Edited 7 years ago by HeroesandvillainsOS

    It's my understanding and experience that using the overrides for the types of forces simply adds those to the spawns, not limits.

    For example, if you place a Platoon 30 with no overrides, notice:

    1. Depending on the map, AO, objective amounts and grid size, more then 30 profiles will spawn.

    2. Let's say without overrides, in this example 50 profiles spawn. Let's say that's 35 infantry, 10 vehicles, and 5 Armored. If you write "2" in the Armored section, the results might end up being 52 total profiles, breaking down as 35 infantry, 10 vehicles, and 7 Armored.

    That's just an example and can fluctuate. You'll rarely spawn the exact numbers every time because I believe there is an element of "randomness."

    Depending on the area you let units spawn, a Battalion of 800 profiles can be a lot! The more units you spawn, the more objectives the commander will have, and every objective will need to be manned by a profile.

    A good rule of thumb for performance is to limit the amount of objectives. You can accomplish this by:

    1. Reducing the size of the AO. And/or...

    2. Reducing the profiles you let spawn by the objective modules themselves.

    2A. Filtering the objectives with the filter dropdowns.

  22. Newer ›
 

or Sign Up to reply!