cregit-Linux how code gets into the kernel

Release 4.7 include/linux/kmsg_dump.h

Directory: include/linux
/*
 * linux/include/kmsg_dump.h
 *
 * Copyright (C) 2009 Net Insight AB
 *
 * Author: Simon Kagstrom <simon.kagstrom@netinsight.net>
 *
 * This file is subject to the terms and conditions of the GNU General Public
 * License.  See the file COPYING in the main directory of this archive
 * for more details.
 */
#ifndef _LINUX_KMSG_DUMP_H

#define _LINUX_KMSG_DUMP_H

#include <linux/errno.h>
#include <linux/list.h>

/*
 * Keep this list arranged in rough order of priority. Anything listed after
 * KMSG_DUMP_OOPS will not be logged by default unless printk.always_kmsg_dump
 * is passed to the kernel.
 */

enum kmsg_dump_reason {
	
KMSG_DUMP_UNDEF,
	
KMSG_DUMP_PANIC,
	
KMSG_DUMP_OOPS,
	
KMSG_DUMP_EMERG,
	
KMSG_DUMP_RESTART,
	
KMSG_DUMP_HALT,
	
KMSG_DUMP_POWEROFF,
};

/**
 * struct kmsg_dumper - kernel crash message dumper structure
 * @list:       Entry in the dumper list (private)
 * @dump:       Call into dumping code which will retrieve the data with
 *              through the record iterator
 * @max_reason: filter for highest reason number that should be dumped
 * @registered: Flag that specifies if this is already registered
 */

struct kmsg_dumper {
	
struct list_head list;
	
void (*dump)(struct kmsg_dumper *dumper, enum kmsg_dump_reason reason);
	
enum kmsg_dump_reason max_reason;
	
bool active;
	
bool registered;

	/* private state of the kmsg iterator */
	
u32 cur_idx;
	
u32 next_idx;
	
u64 cur_seq;
	
u64 next_seq;
};

#ifdef CONFIG_PRINTK
void kmsg_dump(enum kmsg_dump_reason reason);

bool kmsg_dump_get_line_nolock(struct kmsg_dumper *dumper, bool syslog,
			       char *line, size_t size, size_t *len);

bool kmsg_dump_get_line(struct kmsg_dumper *dumper, bool syslog,
			char *line, size_t size, size_t *len);

bool kmsg_dump_get_buffer(struct kmsg_dumper *dumper, bool syslog,
			  char *buf, size_t size, size_t *len);

void kmsg_dump_rewind_nolock(struct kmsg_dumper *dumper);

void kmsg_dump_rewind(struct kmsg_dumper *dumper);

int kmsg_dump_register(struct kmsg_dumper *dumper);

int kmsg_dump_unregister(struct kmsg_dumper *dumper);
#else

static inline void kmsg_dump(enum kmsg_dump_reason reason) { }

Contributors

PersonTokensPropCommitsCommitProp
randy dunlaprandy dunlap10100.00%1100.00%
Total10100.00%1100.00%


static inline bool kmsg_dump_get_line_nolock(struct kmsg_dumper *dumper, bool syslog, const char *line, size_t size, size_t *len) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov30100.00%1100.00%
Total30100.00%1100.00%


static inline bool kmsg_dump_get_line(struct kmsg_dumper *dumper, bool syslog, const char *line, size_t size, size_t *len) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
kay sieverskay sievers30100.00%2100.00%
Total30100.00%2100.00%


static inline bool kmsg_dump_get_buffer(struct kmsg_dumper *dumper, bool syslog, char *buf, size_t size, size_t *len) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
kay sieverskay sievers29100.00%2100.00%
Total29100.00%2100.00%


static inline void kmsg_dump_rewind_nolock(struct kmsg_dumper *dumper) { }

Contributors

PersonTokensPropCommitsCommitProp
anton vorontsovanton vorontsov11100.00%1100.00%
Total11100.00%1100.00%


static inline void kmsg_dump_rewind(struct kmsg_dumper *dumper) { }

Contributors

PersonTokensPropCommitsCommitProp
kay sieverskay sievers11100.00%2100.00%
Total11100.00%2100.00%


static inline int kmsg_dump_register(struct kmsg_dumper *dumper) { return -EINVAL; }

Contributors

PersonTokensPropCommitsCommitProp
randy dunlaprandy dunlap16100.00%1100.00%
Total16100.00%1100.00%


static inline int kmsg_dump_unregister(struct kmsg_dumper *dumper) { return -EINVAL; }

Contributors

PersonTokensPropCommitsCommitProp
randy dunlaprandy dunlap16100.00%1100.00%
Total16100.00%1100.00%

#endif #endif /* _LINUX_KMSG_DUMP_H */

Overall Contributors

PersonTokensPropCommitsCommitProp
kay sieverskay sievers15242.58%222.22%
anton vorontsovanton vorontsov7320.45%111.11%
simon kagstromsimon kagstrom7019.61%111.11%
randy dunlaprandy dunlap5214.57%222.22%
seiji aguchiseiji aguchi51.40%111.11%
matthew garrettmatthew garrett41.12%111.11%
kosaki motohirokosaki motohiro10.28%111.11%
Total357100.00%9100.00%
Directory: include/linux
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}