cregit-Linux how code gets into the kernel

Release 4.7 include/linux/shm.h

Directory: include/linux
#ifndef _LINUX_SHM_H_

#define _LINUX_SHM_H_

#include <linux/list.h>
#include <asm/page.h>
#include <uapi/linux/shm.h>
#include <asm/shmparam.h>


struct shmid_kernel /* private to the kernel */
{	
	
struct kern_ipc_perm	shm_perm;
	
struct file		*shm_file;
	
unsigned long		shm_nattch;
	
unsigned long		shm_segsz;
	
time_t			shm_atim;
	
time_t			shm_dtim;
	
time_t			shm_ctim;
	
pid_t			shm_cprid;
	
pid_t			shm_lprid;
	
struct user_struct	*mlock_user;

	/* The task created the shm object.  NULL if the task is dead. */
	
struct task_struct	*shm_creator;
	
struct list_head	shm_clist;	/* list by creator */
};

/* shm_mode upper byte flags */

#define	SHM_DEST	01000	
/* segment will be destroyed on last detach */

#define SHM_LOCKED      02000   
/* segment will not be swapped */

#define SHM_HUGETLB     04000   
/* segment will use huge TLB pages */

#define SHM_NORESERVE   010000  
/* don't check for reservations */

/* Bits [26:31] are reserved */

/*
 * When SHM_HUGETLB is set bits [26:31] encode the log2 of the huge page size.
 * This gives us 6 bits, which is enough until someone invents 128 bit address
 * spaces.
 *
 * Assume these are all power of twos.
 * When 0 use the default page size.
 */

#define SHM_HUGE_SHIFT  26

#define SHM_HUGE_MASK   0x3f

#define SHM_HUGE_2MB    (21 << SHM_HUGE_SHIFT)

#define SHM_HUGE_1GB    (30 << SHM_HUGE_SHIFT)

#ifdef CONFIG_SYSVIPC

struct sysv_shm {
	
struct list_head shm_clist;
};

long do_shmat(int shmid, char __user *shmaddr, int shmflg, unsigned long *addr,
	      unsigned long shmlba);
bool is_file_shm_hugepages(struct file *file);
void exit_shm(struct task_struct *task);

#define shm_init_task(task) INIT_LIST_HEAD(&(task)->sysvshm.shm_clist)
#else

struct sysv_shm {
	/* empty */
};


static inline long do_shmat(int shmid, char __user *shmaddr, int shmflg, unsigned long *addr, unsigned long shmlba) { return -ENOSYS; }

Contributors

PersonTokensPropCommitsCommitProp
manfred spraulmanfred spraul2683.87%133.33%
will deaconwill deacon412.90%133.33%
andrew mortonandrew morton13.23%133.33%
Total31100.00%3100.00%


static inline bool is_file_shm_hugepages(struct file *file) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
adam litkeadam litke1386.67%150.00%
yaowei baiyaowei bai213.33%150.00%
Total15100.00%2100.00%


static inline void exit_shm(struct task_struct *task) { }

Contributors

PersonTokensPropCommitsCommitProp
vasiliy kulikovvasiliy kulikov11100.00%1100.00%
Total11100.00%1100.00%


static inline void shm_init_task(struct task_struct *task) { }

Contributors

PersonTokensPropCommitsCommitProp
jack millerjack miller11100.00%1100.00%
Total11100.00%1100.00%

#endif #endif /* _LINUX_SHM_H_ */

Overall Contributors

PersonTokensPropCommitsCommitProp
pre-gitpre-git4417.39%627.27%
jack millerjack miller4116.21%14.55%
greg kroah-hartmangreg kroah-hartman3815.02%14.55%
manfred spraulmanfred spraul3413.44%14.55%
vasiliy kulikovvasiliy kulikov2610.28%29.09%
adam litkeadam litke218.30%14.55%
andi kleenandi kleen187.11%14.55%
will deaconwill deacon83.16%14.55%
andrew mortonandrew morton62.37%29.09%
rik van rielrik van riel51.98%14.55%
badari pulavartybadari pulavarty51.98%14.55%
yaowei baiyaowei bai31.19%14.55%
kirill a. shutemovkirill a. shutemov20.79%14.55%
david howellsdavid howells10.40%14.55%
linus torvaldslinus torvalds10.40%14.55%
Total253100.00%22100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}