简体   繁体   English

Linux 虚拟内存限制

[英]Linux virtual memory limit

I am trying to allocate memory for the process (Tsw).我正在尝试为进程(Tsw)分配内存。 Unfortunately, I cannot allocate more than ~ 1 Gb of virtual memory (Allocation of 2MB blocks in a for loop).不幸的是,我不能分配超过 1 Gb 的虚拟内存(在 for 循环中分配 2MB 块)。 No limits change commands during execution.执行期间没有限制更改命令。

Here is the output of cat /proc/$(pidof Tsw)/limits command.这是 cat /proc/$(pidof Tsw)/limits命令的输出。

Limit                     Soft Limit           Hard Limit           Units     
Max cpu time              unlimited            unlimited            seconds   
Max file size             unlimited            unlimited            bytes     
Max data size             unlimited            unlimited            bytes     
Max stack size            8388608              unlimited            bytes     
Max core file size        0                    unlimited            bytes     
Max resident set          unlimited            unlimited            bytes     
Max processes             13633                13633                processes 
Max open files            1024                 4096                 files     
Max locked memory         65536                65536                bytes     
Max address space         unlimited            unlimited            bytes     
Max file locks            unlimited            unlimited            locks     
Max pending signals       13633                13633                signals   
Max msgqueue size         819200               819200               bytes     
Max nice priority         0                    0                    
Max realtime priority     0                    0                    
Max realtime timeout      unlimited            unlimited            us        

Here is the partial output of the top command (note /usr/bin/Tsw , 3rd process from the top):这是 top 命令的部分输出(注意/usr/bin/Tsw ,从顶部开始的第三个进程):

Mem: 1082976K used, 990736K free, 0K shrd, 128K buff, 28136K cached
CPU:   0% usr   4% sys   0% nic  95% idle   0% io   0% irq   0% sirq
Load average: 1.07 0.36 0.13 1/242 2007
  PID  PPID USER     STAT   VSZ %VSZ %CPU COMMAND
 1730  1690 root     S     179m   9%   2% /usr/bin/btsvc_main_9300
  585     1 root     S    45784   2%   2% /usr/bin/brsCore --test-software
 1691     1 root     S     997m  49%   0% /usr/bin/Tsw
 1941     1 root     S     121m   6%   0% /usr/sbin/unifi_helper_tsw --wifi-ptest --wifi-char-device /dev/unifiudi0 --wifi-ptest-firmware ptest/firmware/ptest_unifi_93xx_a07_ptdl.xbv --wifi-ptest-profile ptest/profile/unitest_profile_CSRC9xxx_Cust_BGA.txt --log-level-text CsrWifiPtestApp..A
 1687  1683 root     S     119m   6%   0% /usr/sbin/unifi_helper_tsw --wifi-char-device /dev/unifi0 --wifi-on --wifi-restart-on-error --wifi-exit-on-error --wifi-exit-on-unplug --wifi-address 00:1C:C1:A2:5D:FF --wifi-mib --wifi-add-interface ff:ff:ff:ff:ff:ff
 1693     1 root     S    70452   3%   0% /usr/bin/avTSWCdspAudio.exe /usr/lib/audiomanager/routing/libavPluginRoutingDirana.so
 1219     1 root     S    66740   3%   0% /usr/bin/TSWNav_GNSS
 1215     1 root     S    63460   3%   0% /usr/bin/dlt-system -c /etc/dlt-system.conf
 1039     1 root     S    50464   2%   0% /usr/bin/avDiranaBoot.exe -t DIRANA3 -p /run/audio/dirana_boot.pipe -r 0 -d 0
 1216     1 root     S    48400   2%   0% /usr/bin/RadioAppTSW
 1493     1 root     S    47184   2%   0% /usr/bin/ssw_pers_pccl_hwi_svc
 1494     1 root     S    47180   2%   0% /usr/bin/ssw_pers_pccl_early_svc
 1690     1 root     S    35672   2%   0% /usr/bin/btsvc_main_9300
 1692     1 root     S    30516   1%   0% /usr/bin/tsw-apple-authic-info
    1     0 root     S    30060   1%   0% {systemd} /sbin/init
 1225     1 root     S    28224   1%   0% /usr/bin/TSWNav_Gyro
 1224     1 root     S    28220   1%   0% /usr/bin/TSWNav_Accel
 1212     1 root     S    26968   1%   0% /usr/bin/tsw-ipc-sample
  793     1 root     S    19532   1%   0% /usr/bin/ssw_pers_nba_svc
  622     1 root     S     6656   0%   0% /usr/lib/systemd/systemd-journald
 1232     1 root     S     4440   0%   0% /usr/sbin/sshd -D
  746     1 root     S     3448   0%   0% /usr/lib/systemd/systemd-udevd
 2003  1691 root     S     2960   0%   0% sh -c mount -o remount, rw / && cd usr/bin && top -b -n 1 > statistics_after.txt
 2007  2003 root     R     2960   0%   0% top -b -n 1
 1682    30 root     S     2960   0%   0% {unififw} /bin/sh /usr/sbin/unififw 0 2
 1683  1682 root     S     2960   0%   0% {unififw} /bin/sh /usr/sbin/unififw 0 2
 1209     1 root     S     2708   0%   0% /usr/bin/dlt-daemon
 1694     1 root     S     2660   0%   0% /usr/sbin/conn_wifi_tsw
 1297     1 messageb S     2552   0%   0% /usr/bin/dbus-daemon --system --address=systemd: --nofork --nopidfile --systemd-activation
 1685  1682 root     S     1820   0%   0% logger -t unififw -p daemon.notice
 1625     1 root     S     1816   0%   0% ldattach -8e1s 2000000 19 /dev/ttymxc1
 1161     2 root     SW       0   0%   0% [irq/65-2010000.]
    8     2 root     SW       0   0%   0% [rcu_preempt]
 1629     2 root     SW       0   0%   0% [hydra-sdio-io]
  482     2 root     SW       0   0%   0% [kworker/u8:2]
    6     2 root     SW       0   0%   0% [kworker/u8:0]
  560     2 root     SW       0   0%   0% [ubi_bgt0d]
 1577     2 root     SW       0   0%   0% [file_server_thr]
  699     2 root     SW       0   0%   0% [rtp_parser]
  754     2 root     SW       0   0%   0% [rtp_isr_data_th]
 1464     2 root     SW       0   0%   0% [mmcqd/1]
    3     2 root     SW       0   0%   0% [ksoftirqd/0]
  701     2 root     SW       0   0%   0% [rtp_write_threa]
  755     2 root     SW       0   0%   0% [spi_send_thread]
  756     2 root     SW       0   0%   0% [rtp_parser_thre]
 1163     2 root     SW       0   0%   0% [spi2]
 1387     2 root     SW       0   0%   0% [irq/54-mmc0]
 1630     2 root     SW       0   0%   0% [hydra/complete]
   30     2 root     SW       0   0%   0% [kworker/u8:1]
 1210     2 root     SW       0   0%   0% [kworker/0:2]
    2     0 root     SW       0   0%   0% [kthreadd]
    4     2 root     SW       0   0%   0% [kworker/0:0]
    5     2 root     SW<      0   0%   0% [kworker/0:0H]
    7     2 root     SW       0   0%   0% [migration/0]
    9     2 root     SW       0   0%   0% [rcu_bh]
   10     2 root     SW       0   0%   0% [rcu_sched]
   11     2 root     SW       0   0%   0% [watchdog/0]
   12     2 root     SW       0   0%   0% [watchdog/1]
   13     2 root     SW       0   0%   0% [migration/1]
   14     2 root     SW       0   0%   0% [ksoftirqd/1]
   15     2 root     SW       0   0%   0% [kworker/1:0]
   16     2 root     SW<      0   0%   0% [kworker/1:0H]
   17     2 root     SW       0   0%   0% [watchdog/2]
   18     2 root     SW       0   0%   0% [migration/2]
   19     2 root     SW       0   0%   0% [ksoftirqd/2]
   20     2 root     SW       0   0%   0% [kworker/2:0]
   21     2 root     SW<      0   0%   0% [kworker/2:0H]
   22     2 root     SW       0   0%   0% [watchdog/3]
   23     2 root     SW       0   0%   0% [migration/3]
   24     2 root     SW       0   0%   0% [ksoftirqd/3]
   25     2 root     SW       0   0%   0% [kworker/3:0]
   26     2 root     SW<      0   0%   0% [kworker/3:0H]
   27     2 root     SW<      0   0%   0% [khelper]
   28     2 root     SW       0   0%   0% [kdevtmpfs]
   29     2 root     SW<      0   0%   0% [netns]
   37     2 root     SW       0   0%   0% [kworker/0:1]
   38     2 root     SW       0   0%   0% [kworker/1:1]
   39     2 root     SW       0   0%   0% [kworker/2:1]
   40     2 root     SW       0   0%   0% [kworker/3:1]
  241     2 root     SW<      0   0%   0% [writeback]
  243     2 root     SW<      0   0%   0% [bioset]
  245     2 root     SW<      0   0%   0% [kblockd]
  279     2 root     SW       0   0%   0% [khubd]
  307     2 root     SW       0   0%   0% [ipu1_task]
  308     2 root     SW       0   0%   0% [ipu1_task]
  309     2 root     SW       0   0%   0% [ipu2_task]
  310     2 root     SW       0   0%   0% [ipu2_task]
  343     2 root     SW       0   0%   0% [kswapd0]
  402     2 root     SW       0   0%   0% [fsnotify_mark]
  406     2 root     SW<      0   0%   0% [crypto]
  416     2 root     SW<      0   0%   0% [shm_workqueue]
  429     2 root     SW       0   0%   0% [kworker/2:2]
  474     2 root     SW<      0   0%   0% [usbdiag_queue]
  481     2 root     SW<      0   0%   0% [ci_otg]
  511     2 root     SW<      0   0%   0% [deferwq]
  544     2 root     SW       0   0%   0% [gpmi_statistics]
  700     2 root     SW<      0   0%   0% [rtp_admin]
  753     2 root     SW       0   0%   0% [spi0]
  795     2 root     SW       0   0%   0% [kworker/1:2]
 1040     2 root     SW       0   0%   0% [kworker/3:2]
 1152     2 root     SW       0   0%   0% [spi1]
 1177     2 root     SW       0   0%   0% [spi4]
 1269     2 root     SW<      0   0%   0% [vpu_wq]
 1406     2 root     SW       0   0%   0% [ubifs_bgt0_60]
 1409     2 root     SW       0   0%   0% [irq/56-mmc1]
 1413     2 root     SW       0   0%   0% [kworker/u8:3]
 1465     2 root     SW       0   0%   0% [mmcqd/1boot0]
 1466     2 root     SW       0   0%   0% [mmcqd/1boot1]
 1467     2 root     SW       0   0%   0% [mmcqd/1rpmb]
 1480     2 root     SW<      0   0%   0% [kworker/0:1H]
 1482     2 root     SW<      0   0%   0% [kworker/2:1H]
 1486     2 root     SW<      0   0%   0% [kworker/1:1H]
 1533     2 root     SW       0   0%   0% [jbd2/mmcblk1p3-]
 1534     2 root     SW<      0   0%   0% [ext4-dio-unwrit]
 1536     2 root     SW       0   0%   0% [jbd2/mmcblk1p2-]
 1537     2 root     SW<      0   0%   0% [ext4-dio-unwrit]
 1578     2 root     SW<      0   0%   0% [coredump_wq]
 1631     2 root     SW       0   0%   0% [service_mgr_thr]
 1679     2 root     SW<      0   0%   0% [unifi_workq]
 1717     2 root     SW       0   0%   0% [ubifs_bgt0_50]
 1758     2 root     SW       0   0%   0% [ubifs_bgt0_17]
 1759     2 root     SW       0   0%   0% [UNIFI_BH]
 1766     2 root     SW       0   0%   0% [hydra/complete]
 1936     2 root     SW       0   0%   0% [reader]
 1937     2 root     SW       0   0%   0% [writer]

Here is how I do the allocation:这是我如何进行分配:

// RAM_SIZE = 1.5 Gb
// RAM_BLOCK_TEST = 2 Mb
#define RAM_SIZE (1024U * 1024U * 1536U) 
#define RAM_BLOCK_TEST (1024U * 1024U * 2U)

uint32_t uiMemBlockCount = 0;
// uiLoopNr = 768
uint32_t uiLoopNr = (uint32_t)RAM_SIZE/(uint32_t)RAM_BLOCK_TEST;
uint8_t* pcMemArray[uiLoopNr];

for(uiMemBlockCount = 0; uiMemBlockCount < uiLoopNr; uiMemBlockCount++)
{
    pcMemArray[uiMemBlockCount] = (uint8_t*)calloc(RAM_BLOCK_TEST, sizeof(uint8_t));
    if (NULL == pcMemArray[uiMemBlockCount])
    {
        printf("Allocated %u block(s) of memory with %d size", uiMemBlockCount, RAM_BLOCK_TEST);
        break;
    }
}

Maybe there are other limits in Linux OS that does not allow me to do this?也许 Linux 操作系统中还有其他限制不允许我这样做? Thank you!谢谢!

I have found the problem.我找到了问题所在。

Virtual kernel memory layout:
vector : 0xffff0000 - 0xffff1000 ( 4 kB)
fixmap : 0xfff00000 - 0xfffe0000 ( 896 kB)
vmalloc : 0xc0800000 - 0xff000000 (1000 MB)
lowmem : 0x40000000 - 0xc0000000 (2048 MB)
modules : 0x3f000000 - 0x40000000 ( 16 MB)
.text : 0x40008000 - 0x40411ef4 (4136 kB)
.init : 0x40412000 - 0x4043ce80 ( 172 kB)
.data : 0x4043e000 - 0x404607c0 ( 138 kB)
.bss : 0x404607c0 - 0x40498208 ( 223 kB)

lowmem starts at 0x40000000. lowmem 从 0x40000000 开始。
So I can have no more than 1 Gb of virtual memory per process.所以我每个进程的虚拟内存不能超过 1 Gb。

This can be changed using CONFIG_PAGE_OFFSET in kernel config.这可以使用内核配置中的 CONFIG_PAGE_OFFSET 进行更改。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM