FreeBSD vice OS X memory management

Chuck Swiger cswiger at mac.com
Wed Apr 25 17:44:20 UTC 2012


On Apr 25, 2012, at 5:31 AM, jb wrote:
> does OS X kernel share any code with FreeBSD kernel's memory management subsystem ?

The simple answer is no.  A more complex answer:

% grep -ri freebsd xnu-1699.24.23 | wc -l
     520

% grep -ril freebsd xnu-1699.24.23 | sort | uniq

-------------- next part --------------
% grep -ril freebsd xnu-1699.24.23 | sort | uniq                                                                              ~/Downloads
xnu-1699.24.23/EXTERNAL_HEADERS/stdbool.h
xnu-1699.24.23/bsd/bsm/audit.h
xnu-1699.24.23/bsd/bsm/audit_domain.h
xnu-1699.24.23/bsd/bsm/audit_errno.h
xnu-1699.24.23/bsd/bsm/audit_fcntl.h
xnu-1699.24.23/bsd/bsm/audit_kevents.h
xnu-1699.24.23/bsd/crypto/aes/gen/aesopt.h
xnu-1699.24.23/bsd/crypto/blowfish/bf_enc.c
xnu-1699.24.23/bsd/crypto/blowfish/bf_locl.h
xnu-1699.24.23/bsd/crypto/blowfish/bf_pi.h
xnu-1699.24.23/bsd/crypto/blowfish/bf_skey.c
xnu-1699.24.23/bsd/crypto/blowfish/blowfish.h
xnu-1699.24.23/bsd/crypto/cast128/cast128.c
xnu-1699.24.23/bsd/crypto/cast128/cast128.h
xnu-1699.24.23/bsd/crypto/cast128/cast128_subkey.h
xnu-1699.24.23/bsd/crypto/des/des.h
xnu-1699.24.23/bsd/crypto/des/des_ecb.c
xnu-1699.24.23/bsd/crypto/des/des_enc.c
xnu-1699.24.23/bsd/crypto/des/des_locl.h
xnu-1699.24.23/bsd/crypto/des/des_setkey.c
xnu-1699.24.23/bsd/crypto/des/podd.h
xnu-1699.24.23/bsd/crypto/des/sk.h
xnu-1699.24.23/bsd/crypto/des/spr.h
xnu-1699.24.23/bsd/crypto/rc4/rc4.c
xnu-1699.24.23/bsd/crypto/rc4/rc4.h
xnu-1699.24.23/bsd/crypto/sha2/sha2.c
xnu-1699.24.23/bsd/crypto/sha2/sha2.h
xnu-1699.24.23/bsd/dev/dtrace/blist.c
xnu-1699.24.23/bsd/dev/dtrace/blist.h
xnu-1699.24.23/bsd/dev/memdev.c
xnu-1699.24.23/bsd/dev/vn/vn.c
xnu-1699.24.23/bsd/hfs/hfs_lookup.c
xnu-1699.24.23/bsd/hfs/hfscommon/headers/RedBlackTree.h
xnu-1699.24.23/bsd/kern/kern_event.c
xnu-1699.24.23/bsd/kern/kern_mib.c
xnu-1699.24.23/bsd/kern/kern_newsysctl.c
xnu-1699.24.23/bsd/kern/kern_resource.c
xnu-1699.24.23/bsd/kern/makesyscalls.sh
xnu-1699.24.23/bsd/kern/sys_pipe.c
xnu-1699.24.23/bsd/kern/syscalls.master
xnu-1699.24.23/bsd/kern/tty.c
xnu-1699.24.23/bsd/kern/uipc_socket.c
xnu-1699.24.23/bsd/kern/uipc_socket2.c
xnu-1699.24.23/bsd/libkern/strsep.c
xnu-1699.24.23/bsd/man/man2/aio_cancel.2
xnu-1699.24.23/bsd/man/man2/aio_error.2
xnu-1699.24.23/bsd/man/man2/aio_read.2
xnu-1699.24.23/bsd/man/man2/aio_return.2
xnu-1699.24.23/bsd/man/man2/aio_suspend.2
xnu-1699.24.23/bsd/man/man2/aio_write.2
xnu-1699.24.23/bsd/man/man2/audit.2
xnu-1699.24.23/bsd/man/man2/auditctl.2
xnu-1699.24.23/bsd/man/man2/auditon.2
xnu-1699.24.23/bsd/man/man2/getaudit.2
xnu-1699.24.23/bsd/man/man2/getauid.2
xnu-1699.24.23/bsd/man/man2/getdtablesize.2
xnu-1699.24.23/bsd/man/man2/getlcid.2
xnu-1699.24.23/bsd/man/man2/getpgrp.2
xnu-1699.24.23/bsd/man/man2/getsid.2
xnu-1699.24.23/bsd/man/man2/i386_get_ldt.2
xnu-1699.24.23/bsd/man/man2/issetugid.2
xnu-1699.24.23/bsd/man/man2/kqueue.2
xnu-1699.24.23/bsd/man/man2/mmap.2
xnu-1699.24.23/bsd/man/man2/mprotect.2
xnu-1699.24.23/bsd/man/man2/msync.2
xnu-1699.24.23/bsd/man/man2/read.2
xnu-1699.24.23/bsd/man/man2/semctl.2
xnu-1699.24.23/bsd/man/man2/semget.2
xnu-1699.24.23/bsd/man/man2/semop.2
xnu-1699.24.23/bsd/man/man2/sendfile.2
xnu-1699.24.23/bsd/man/man2/setaudit.2
xnu-1699.24.23/bsd/man/man2/setauid.2
xnu-1699.24.23/bsd/man/man2/setlcid.2
xnu-1699.24.23/bsd/man/man2/setregid.2
xnu-1699.24.23/bsd/man/man2/setreuid.2
xnu-1699.24.23/bsd/man/man2/sigaction.2
xnu-1699.24.23/bsd/man/man2/undelete.2
xnu-1699.24.23/bsd/man/man2/utimes.2
xnu-1699.24.23/bsd/man/man2/write.2
xnu-1699.24.23/bsd/man/man3/queue.3
xnu-1699.24.23/bsd/man/man4/aio.4
xnu-1699.24.23/bsd/man/man4/audit.4
xnu-1699.24.23/bsd/man/man4/auditpipe.4
xnu-1699.24.23/bsd/man/man4/bpf.4
xnu-1699.24.23/bsd/man/man4/divert.4
xnu-1699.24.23/bsd/man/man4/dummynet.4
xnu-1699.24.23/bsd/man/man4/faith.4
xnu-1699.24.23/bsd/man/man4/gif.4
xnu-1699.24.23/bsd/man/man4/ifmib.4
xnu-1699.24.23/bsd/man/man4/inet6.4
xnu-1699.24.23/bsd/man/man4/ipfirewall.4
xnu-1699.24.23/bsd/man/man4/ipsec.4
xnu-1699.24.23/bsd/man/man4/stf.4
xnu-1699.24.23/bsd/man/man4/tty.4
xnu-1699.24.23/bsd/man/man9/copy.9
xnu-1699.24.23/bsd/man/man9/fetch.9
xnu-1699.24.23/bsd/man/man9/intro.9
xnu-1699.24.23/bsd/man/man9/store.9
xnu-1699.24.23/bsd/man/man9/style.9
xnu-1699.24.23/bsd/miscfs/devfs/README
xnu-1699.24.23/bsd/miscfs/devfs/devfs.h
xnu-1699.24.23/bsd/miscfs/devfs/devfs_tree.c
xnu-1699.24.23/bsd/miscfs/devfs/devfs_vfsops.c
xnu-1699.24.23/bsd/miscfs/devfs/devfs_vnops.c
xnu-1699.24.23/bsd/miscfs/devfs/devfsdefs.h
xnu-1699.24.23/bsd/net/bpf.c
xnu-1699.24.23/bsd/net/bpf.h
xnu-1699.24.23/bsd/net/bpf_compat.h
xnu-1699.24.23/bsd/net/bpf_filter.c
xnu-1699.24.23/bsd/net/bpfdesc.h
xnu-1699.24.23/bsd/net/bridgestp.c
xnu-1699.24.23/bsd/net/bridgestp.h
xnu-1699.24.23/bsd/net/if.c
xnu-1699.24.23/bsd/net/if.h
xnu-1699.24.23/bsd/net/if_arp.h
xnu-1699.24.23/bsd/net/if_bridge.c
xnu-1699.24.23/bsd/net/if_bridgevar.h
xnu-1699.24.23/bsd/net/if_dl.h
xnu-1699.24.23/bsd/net/if_gif.c
xnu-1699.24.23/bsd/net/if_loop.c
xnu-1699.24.23/bsd/net/if_media.c
xnu-1699.24.23/bsd/net/if_media.h
xnu-1699.24.23/bsd/net/if_mib.c
xnu-1699.24.23/bsd/net/if_mib.h
xnu-1699.24.23/bsd/net/if_ppp.h
xnu-1699.24.23/bsd/net/if_pppvar.h
xnu-1699.24.23/bsd/net/if_stf.c
xnu-1699.24.23/bsd/net/if_types.h
xnu-1699.24.23/bsd/net/if_var.h
xnu-1699.24.23/bsd/net/if_vlan.c
xnu-1699.24.23/bsd/net/if_vlan_var.h
xnu-1699.24.23/bsd/net/iso88025.h
xnu-1699.24.23/bsd/net/net_osdep.h
xnu-1699.24.23/bsd/net/radix.c
xnu-1699.24.23/bsd/net/radix.h
xnu-1699.24.23/bsd/net/raw_usrreq.c
xnu-1699.24.23/bsd/net/route.c
xnu-1699.24.23/bsd/net/route.h
xnu-1699.24.23/bsd/net/rtsock.c
xnu-1699.24.23/bsd/net/slip.h
xnu-1699.24.23/bsd/netat/at_proto.c
xnu-1699.24.23/bsd/netinet/icmp_var.h
xnu-1699.24.23/bsd/netinet/if_ether.h
xnu-1699.24.23/bsd/netinet/igmp.h
xnu-1699.24.23/bsd/netinet/in.c
xnu-1699.24.23/bsd/netinet/in.h
xnu-1699.24.23/bsd/netinet/in_pcb.c
xnu-1699.24.23/bsd/netinet/in_pcb.h
xnu-1699.24.23/bsd/netinet/in_rmx.c
xnu-1699.24.23/bsd/netinet/in_systm.h
xnu-1699.24.23/bsd/netinet/in_var.h
xnu-1699.24.23/bsd/netinet/ip.h
xnu-1699.24.23/bsd/netinet/ip_compat.h
xnu-1699.24.23/bsd/netinet/ip_divert.c
xnu-1699.24.23/bsd/netinet/ip_divert.h
xnu-1699.24.23/bsd/netinet/ip_dummynet.c
xnu-1699.24.23/bsd/netinet/ip_dummynet.h
xnu-1699.24.23/bsd/netinet/ip_encap.c
xnu-1699.24.23/bsd/netinet/ip_fw2.c
xnu-1699.24.23/bsd/netinet/ip_fw2.h
xnu-1699.24.23/bsd/netinet/ip_icmp.h
xnu-1699.24.23/bsd/netinet/ip_id.c
xnu-1699.24.23/bsd/netinet/ip_input.c
xnu-1699.24.23/bsd/netinet/ip_mroute.c
xnu-1699.24.23/bsd/netinet/ip_output.c
xnu-1699.24.23/bsd/netinet/tcp.h
xnu-1699.24.23/bsd/netinet/tcp_cc.h
xnu-1699.24.23/bsd/netinet/tcp_debug.c
xnu-1699.24.23/bsd/netinet/tcp_debug.h
xnu-1699.24.23/bsd/netinet/tcp_fsm.h
xnu-1699.24.23/bsd/netinet/tcp_input.c
xnu-1699.24.23/bsd/netinet/tcp_output.c
xnu-1699.24.23/bsd/netinet/tcp_seq.h
xnu-1699.24.23/bsd/netinet/tcp_subr.c
xnu-1699.24.23/bsd/netinet/tcp_timer.c
xnu-1699.24.23/bsd/netinet/tcp_timer.h
xnu-1699.24.23/bsd/netinet/tcp_usrreq.c
xnu-1699.24.23/bsd/netinet/tcp_var.h
xnu-1699.24.23/bsd/netinet/tcpip.h
xnu-1699.24.23/bsd/netinet/udp_usrreq.c
xnu-1699.24.23/bsd/netinet6/ah.h
xnu-1699.24.23/bsd/netinet6/ah6.h
xnu-1699.24.23/bsd/netinet6/ah_core.c
xnu-1699.24.23/bsd/netinet6/ah_input.c
xnu-1699.24.23/bsd/netinet6/ah_output.c
xnu-1699.24.23/bsd/netinet6/dest6.c
xnu-1699.24.23/bsd/netinet6/esp.h
xnu-1699.24.23/bsd/netinet6/esp6.h
xnu-1699.24.23/bsd/netinet6/esp_core.c
xnu-1699.24.23/bsd/netinet6/esp_input.c
xnu-1699.24.23/bsd/netinet6/esp_output.c
xnu-1699.24.23/bsd/netinet6/esp_rijndael.c
xnu-1699.24.23/bsd/netinet6/esp_rijndael.h
xnu-1699.24.23/bsd/netinet6/frag6.c
xnu-1699.24.23/bsd/netinet6/icmp6.c
xnu-1699.24.23/bsd/netinet6/icmp6.h
xnu-1699.24.23/bsd/netinet6/in6.c
xnu-1699.24.23/bsd/netinet6/in6.h
xnu-1699.24.23/bsd/netinet6/in6_gif.c
xnu-1699.24.23/bsd/netinet6/in6_gif.h
xnu-1699.24.23/bsd/netinet6/in6_ifattach.c
xnu-1699.24.23/bsd/netinet6/in6_proto.c
xnu-1699.24.23/bsd/netinet6/in6_rmx.c
xnu-1699.24.23/bsd/netinet6/in6_src.c
xnu-1699.24.23/bsd/netinet6/in6_var.h
xnu-1699.24.23/bsd/netinet6/ip6.h
xnu-1699.24.23/bsd/netinet6/ip6_ecn.h
xnu-1699.24.23/bsd/netinet6/ip6_forward.c
xnu-1699.24.23/bsd/netinet6/ip6_fw.c
xnu-1699.24.23/bsd/netinet6/ip6_input.c
xnu-1699.24.23/bsd/netinet6/ip6_mroute.c
xnu-1699.24.23/bsd/netinet6/ip6_mroute.h
xnu-1699.24.23/bsd/netinet6/ip6_output.c
xnu-1699.24.23/bsd/netinet6/ip6_var.h
xnu-1699.24.23/bsd/netinet6/ip6protosw.h
xnu-1699.24.23/bsd/netinet6/ipcomp.h
xnu-1699.24.23/bsd/netinet6/ipcomp6.h
xnu-1699.24.23/bsd/netinet6/ipcomp_core.c
xnu-1699.24.23/bsd/netinet6/ipcomp_input.c
xnu-1699.24.23/bsd/netinet6/ipcomp_output.c
xnu-1699.24.23/bsd/netinet6/ipsec.c
xnu-1699.24.23/bsd/netinet6/ipsec.h
xnu-1699.24.23/bsd/netinet6/ipsec6.h
xnu-1699.24.23/bsd/netinet6/mld6.h
xnu-1699.24.23/bsd/netinet6/mld6_var.h
xnu-1699.24.23/bsd/netinet6/nd6.c
xnu-1699.24.23/bsd/netinet6/nd6.h
xnu-1699.24.23/bsd/netinet6/nd6_nbr.c
xnu-1699.24.23/bsd/netinet6/nd6_rtr.c
xnu-1699.24.23/bsd/netinet6/pim6.h
xnu-1699.24.23/bsd/netinet6/pim6_var.h
xnu-1699.24.23/bsd/netinet6/raw_ip6.c
xnu-1699.24.23/bsd/netinet6/raw_ip6.h
xnu-1699.24.23/bsd/netinet6/route6.c
xnu-1699.24.23/bsd/netinet6/scope6.c
xnu-1699.24.23/bsd/netinet6/scope6_var.h
xnu-1699.24.23/bsd/netinet6/tcp6_var.h
xnu-1699.24.23/bsd/netinet6/udp6_output.c
xnu-1699.24.23/bsd/netinet6/udp6_usrreq.c
xnu-1699.24.23/bsd/netkey/key.c
xnu-1699.24.23/bsd/netkey/key_debug.c
xnu-1699.24.23/bsd/netkey/keysock.c
xnu-1699.24.23/bsd/nfs/nfs.h
xnu-1699.24.23/bsd/nfs/nfs_bio.c
xnu-1699.24.23/bsd/nfs/nfs_lock.h
xnu-1699.24.23/bsd/nfs/nfs_node.c
xnu-1699.24.23/bsd/nfs/nfs_serv.c
xnu-1699.24.23/bsd/nfs/nfs_socket.c
xnu-1699.24.23/bsd/nfs/nfs_srvcache.c
xnu-1699.24.23/bsd/nfs/nfs_subs.c
xnu-1699.24.23/bsd/nfs/nfs_syscalls.c
xnu-1699.24.23/bsd/nfs/nfs_vfsops.c
xnu-1699.24.23/bsd/nfs/nfs_vnops.c
xnu-1699.24.23/bsd/nfs/nfsdiskless.h
xnu-1699.24.23/bsd/nfs/nfsm_subs.h
xnu-1699.24.23/bsd/nfs/nfsmount.h
xnu-1699.24.23/bsd/nfs/nfsnode.h
xnu-1699.24.23/bsd/nfs/nfsproto.h
xnu-1699.24.23/bsd/nfs/nfsrvcache.h
xnu-1699.24.23/bsd/nfs/rpcv2.h
xnu-1699.24.23/bsd/nfs/xdr_subs.h
xnu-1699.24.23/bsd/security/audit/audit.c
xnu-1699.24.23/bsd/security/audit/audit_bsm_klib.c
xnu-1699.24.23/bsd/sys/domain.h
xnu-1699.24.23/bsd/sys/event.h
xnu-1699.24.23/bsd/sys/eventvar.h
xnu-1699.24.23/bsd/sys/linker_set.h
xnu-1699.24.23/bsd/sys/lockf.h
xnu-1699.24.23/bsd/sys/mbuf.h
xnu-1699.24.23/bsd/sys/pipe.h
xnu-1699.24.23/bsd/sys/poll.h
xnu-1699.24.23/bsd/sys/priv.h
xnu-1699.24.23/bsd/sys/protosw.h
xnu-1699.24.23/bsd/sys/queue.h
xnu-1699.24.23/bsd/sys/sbuf.h
xnu-1699.24.23/bsd/sys/socket.h
xnu-1699.24.23/bsd/sys/socketvar.h
xnu-1699.24.23/bsd/sys/stat.h
xnu-1699.24.23/bsd/sys/syslog.h
xnu-1699.24.23/bsd/sys/time.h
xnu-1699.24.23/bsd/sys/vnioctl.h
xnu-1699.24.23/bsd/vfs/vfs_cache.c
xnu-1699.24.23/security/_label.h
xnu-1699.24.23/security/conf/copyright.nai
xnu-1699.24.23/security/mac.h
xnu-1699.24.23/security/mac_audit.c
xnu-1699.24.23/security/mac_base.c
xnu-1699.24.23/security/mac_file.c
xnu-1699.24.23/security/mac_framework.h
xnu-1699.24.23/security/mac_inet.c
xnu-1699.24.23/security/mac_internal.h
xnu-1699.24.23/security/mac_label.c
xnu-1699.24.23/security/mac_net.c
xnu-1699.24.23/security/mac_pipe.c
xnu-1699.24.23/security/mac_policy.h
xnu-1699.24.23/security/mac_port.c
xnu-1699.24.23/security/mac_posix_sem.c
xnu-1699.24.23/security/mac_posix_shm.c
xnu-1699.24.23/security/mac_process.c
xnu-1699.24.23/security/mac_socket.c
xnu-1699.24.23/security/mac_system.c
xnu-1699.24.23/security/mac_sysv_msg.c
xnu-1699.24.23/security/mac_sysv_sem.c
xnu-1699.24.23/security/mac_sysv_shm.c
xnu-1699.24.23/security/mac_task.c
xnu-1699.24.23/security/mac_vfs.c
-------------- next part --------------


> Something is deeply broken in OS X memory management
> http://workstuff.tumblr.com/post/20464780085/something-is-deeply-broken-in-os-x-
> memory-management

Hmm.  Certainly it is true that things like mds and the Safari Web Content are rather memory hungry, and having mds generating initial indexes or doing a big update will slow down Time Machine due to disk I/O contention.  

Flushing the inactive pages and blowing away disk caching can help performance of a foreground task at the expense of background tasks, but tuning for overall throughput and avoiding deadlock / livelock is probably a wiser design decision than concentrating purely on foreground tasks.

Killing off the VM pager is extreme: most folks prefer a program to continue to run rather than crash, although the latter behavior is also a sign that the program itself is not well-written.

> One of the problems that caught my eyes was inactive memory reclamation.
> I remember some time ago there was a thread here with similar topic.
> http://lists.freebsd.org/pipermail/freebsd-questions/2012-March/239121.html

Yes.  Understanding VM takes a fair amount of background knowledge and making useful comparisons (ie, testable, repeatable, etc) involves gathering data.  Filing good bug reports with data and reproducible test cases helps problems get resolved.

Regards,
-- 
-Chuck



More information about the freebsd-questions mailing list