[
  {
    "path": "Makefile",
    "content": "# used by Linux kernel\nobj-y = mymain.o myinterrupt.o\n\n# the generic parts\nLINUX_URL = https://www.kernel.org/pub/linux/kernel/v4.x\nKERNEL = linux-4.1\nLINUX_FILE = downloads/$(KERNEL).tar.xz\nLINUX_MD5 = \"fe9dc0f6729f36400ea81aa41d614c37\"\nPATCH_FILE = linux-4_1-mykernel.patch\nOUT = $(PWD)/.out\n\nALL = .stamps/downloads .stamps/setup .stamps/build\n.PHONY: all\nall: $(ALL)\n\nTMPFILE := $(shell mktemp)\n\n.stamps:\n\t@mkdir -p $@\n\nto-md5 = $1 $(addsuffix .md5,$1)\n%.md5: FORCE\n\t@$(if $(filter-out $(shell cat $@ 2>/dev/null),$(shell md5sum $*)),md5sum $* > $@)\nFORCE:\n\n$(LINUX_FILE):\n\tmkdir -p downloads\n\t(cd downloads; wget -c $(LINUX_URL)/$(KERNEL).tar.xz)\n\n.stamps/downloads: $(call to-md5,$(LINUX_FILE)) .stamps\n\t@echo $(LINUX_MD5) > $(TMPFILE)\n\t@cmp -n 32 $(TMPFILE) $<.md5 >/dev/null || (echo \"File checksum mismatch!\"; exit 1)\n\t@touch $@\n\n.stamps/setup: .stamps/extract .stamps/patch .stamps/config\n\t@touch $@\n\n.stamps/extract: $(LINUX_FILE)\n\ttar Jxf $<\n\t(cd $(KERNEL); ln -s ../src mysrc)\n\t@touch $@\n\n.stamps/patch:\n\t(cd $(KERNEL); \\\n\t patch --dry-run -f -p1 < ../patches/$(PATCH_FILE) >/dev/null && \\\n\t patch -p1 < ../patches/$(PATCH_FILE)) || touch $@\n\n.stamps/config:\n\t@mkdir -p $(OUT)\n\t(cd $(KERNEL); \\\n\t cp -f ../configs/mini-x86.config $(OUT)/.config; \\\n\t make O=$(OUT) oldconfig)\n\t@touch $@\n\n# number of CPUs\nifndef CPUS\nCPUS := $(shell grep -c ^processor /proc/cpuinfo 2>/dev/null || \\\n          sysctl -n hw.ncpu)                                          \nendif\n\n.stamps/build: $(KERNEL)/Makefile \\\n              src/scheduler.c src/main.c src/mypcb.h\n\t(cd $(KERNEL); $(MAKE) O=$(OUT) -j $(CPUS))\n\t@touch $@\n\nrun: $(OUT)/arch/x86/boot/bzImage\n\tqemu-system-i386 -kernel $<\n\nclean:\n\t$(MAKE) -C $(KERNEL) O=$(OUT) clean\n\trm -f .stamps/build\n\ndistclean: clean\n\trm -rf .stamps $(OUT)\n\trm -rf $(KERNEL)\n"
  },
  {
    "path": "README.md",
    "content": "Welcome to the kernel-in-kernel repository. Here you will find the\nstraightfoward environment to develop your own operating system kernel\nby means of reusing Linux kernel, that implies that you do not have to\nworry about low-level initilizations, platform-specific configurations,\nand even device drivers.\n\nThis work was inspired by [mykernel](https://github.com/mengning/mykernel/),\nthe simple simulation of the linux process scheduling.\nMaintained by `Jim Huang <jserv.tw@gmail.com>`.\n\nBuild Instructions\n------------------\nUnless otherwise noted, file and directory names refer to this repository.\n\n1. Install [QEMU](http://www.qemu.org) and ensure its availability of x86 support.\n   For Debian/Ubuntu Linux, you can simply do `sudo apt-get install qemu-system-x86`.\n\n2. Return to the kernel-in-kernel top-level directory. Do a `make`. This will\n   do several things including downloading Linux kernel 4.1 as the base of\n   your own kernel, configuring the minimal development environment, and\n   building everything from scratch.\n\n3. At present, only IA32 image is generated, but it should be reasonably easy\n   to enable other architectures originally supported by Linux kernel.\n\nModify Your Own Kernel\n----------------------\nHacking kernel is interesting, and you should take a look over the files in\nthe `src` directory:\n* `mypcb.h`: the cutomized process control block\n* `scheduler.c`: timer interrupt handler and simple scheduler\n* `main.c`: entry point\n\nRunning kernel-in-kernel\n------------------------\nRun `make run` and and you should see this:\n\n```\nthis is process 0 -\nthis is process 0 +\nthis is process 1 -\nthis is process 1 +\nthis is process 2 -\nthis is process 2 +\nthis is process 3 -\nthis is process 3 +\n```\n\nLicensing\n=========\nSince kernel-in-kernel is built directly upon Linux kernel, it is certainly\nlicensed under GNU GPL v2.\n"
  },
  {
    "path": "configs/mini-x86.config",
    "content": "# CONFIG_64BIT is not set\n\nCONFIG_X86_32=y\nCONFIG_X86=y\nCONFIG_INSTRUCTION_DECODER=y\nCONFIG_OUTPUT_FORMAT=\"elf32-i386\"\nCONFIG_ARCH_DEFCONFIG=\"arch/x86/configs/i386_defconfig\"\nCONFIG_LOCKDEP_SUPPORT=y\nCONFIG_STACKTRACE_SUPPORT=y\nCONFIG_HAVE_LATENCYTOP_SUPPORT=y\nCONFIG_MMU=y\nCONFIG_NEED_SG_DMA_LENGTH=y\nCONFIG_GENERIC_ISA_DMA=y\nCONFIG_GENERIC_HWEIGHT=y\nCONFIG_ARCH_MAY_HAVE_PC_FDC=y\nCONFIG_RWSEM_XCHGADD_ALGORITHM=y\nCONFIG_GENERIC_CALIBRATE_DELAY=y\nCONFIG_ARCH_HAS_CPU_RELAX=y\nCONFIG_ARCH_HAS_CACHE_LINE_SIZE=y\nCONFIG_HAVE_SETUP_PER_CPU_AREA=y\nCONFIG_NEED_PER_CPU_EMBED_FIRST_CHUNK=y\nCONFIG_NEED_PER_CPU_PAGE_FIRST_CHUNK=y\nCONFIG_ARCH_HIBERNATION_POSSIBLE=y\nCONFIG_ARCH_SUSPEND_POSSIBLE=y\nCONFIG_ARCH_WANT_HUGE_PMD_SHARE=y\nCONFIG_ARCH_WANT_GENERAL_HUGETLB=y\nCONFIG_ARCH_SUPPORTS_OPTIMIZED_INLINING=y\nCONFIG_ARCH_SUPPORTS_DEBUG_PAGEALLOC=y\nCONFIG_X86_32_LAZY_GS=y\nCONFIG_ARCH_HWEIGHT_CFLAGS=\"-fcall-saved-ecx -fcall-saved-edx\"\nCONFIG_ARCH_SUPPORTS_UPROBES=y\nCONFIG_FIX_EARLYCON_MEM=y\nCONFIG_PGTABLE_LEVELS=2\nCONFIG_DEFCONFIG_LIST=\"/lib/modules/$UNAME_RELEASE/.config\"\nCONFIG_IRQ_WORK=y\nCONFIG_BUILDTIME_EXTABLE_SORT=y\n\n#\n# General setup\n#\nCONFIG_BROKEN_ON_SMP=y\nCONFIG_INIT_ENV_ARG_LIMIT=32\nCONFIG_CROSS_COMPILE=\"\"\n# CONFIG_COMPILE_TEST is not set\nCONFIG_LOCALVERSION=\"\"\n# CONFIG_LOCALVERSION_AUTO is not set\nCONFIG_HAVE_KERNEL_GZIP=y\nCONFIG_HAVE_KERNEL_BZIP2=y\nCONFIG_HAVE_KERNEL_LZMA=y\nCONFIG_HAVE_KERNEL_XZ=y\nCONFIG_HAVE_KERNEL_LZO=y\nCONFIG_HAVE_KERNEL_LZ4=y\nCONFIG_KERNEL_GZIP=y\n# CONFIG_KERNEL_BZIP2 is not set\n# CONFIG_KERNEL_LZMA is not set\n# CONFIG_KERNEL_XZ is not set\n# CONFIG_KERNEL_LZO is not set\n# CONFIG_KERNEL_LZ4 is not set\nCONFIG_DEFAULT_HOSTNAME=\"(none)\"\n# CONFIG_SYSVIPC is not set\n# CONFIG_CROSS_MEMORY_ATTACH is not set\n# CONFIG_FHANDLE is not set\n# CONFIG_USELIB is not set\nCONFIG_HAVE_ARCH_AUDITSYSCALL=y\n\n#\n# IRQ subsystem\n#\nCONFIG_GENERIC_IRQ_PROBE=y\nCONFIG_GENERIC_IRQ_SHOW=y\nCONFIG_IRQ_FORCED_THREADING=y\nCONFIG_SPARSE_IRQ=y\nCONFIG_CLOCKSOURCE_WATCHDOG=y\nCONFIG_ARCH_CLOCKSOURCE_DATA=y\nCONFIG_CLOCKSOURCE_VALIDATE_LAST_CYCLE=y\nCONFIG_GENERIC_TIME_VSYSCALL=y\nCONFIG_GENERIC_CLOCKEVENTS=y\nCONFIG_GENERIC_CLOCKEVENTS_MIN_ADJUST=y\nCONFIG_GENERIC_CMOS_UPDATE=y\n\n#\n# Timers subsystem\n#\nCONFIG_TICK_ONESHOT=y\nCONFIG_HZ_PERIODIC=y\n# CONFIG_NO_HZ_IDLE is not set\n# CONFIG_NO_HZ is not set\nCONFIG_HIGH_RES_TIMERS=y\n\n#\n# CPU/Task time and stats accounting\n#\nCONFIG_TICK_CPU_ACCOUNTING=y\n# CONFIG_IRQ_TIME_ACCOUNTING is not set\n\n#\n# RCU Subsystem\n#\nCONFIG_TINY_RCU=y\nCONFIG_SRCU=y\n# CONFIG_TASKS_RCU is not set\n# CONFIG_RCU_STALL_COMMON is not set\n# CONFIG_TREE_RCU_TRACE is not set\nCONFIG_RCU_KTHREAD_PRIO=0\n# CONFIG_RCU_EXPEDITE_BOOT is not set\n# CONFIG_BUILD_BIN2C is not set\n# CONFIG_IKCONFIG is not set\nCONFIG_LOG_BUF_SHIFT=18\nCONFIG_HAVE_UNSTABLE_SCHED_CLOCK=y\n# CONFIG_CGROUPS is not set\n# CONFIG_CHECKPOINT_RESTORE is not set\n# CONFIG_SCHED_AUTOGROUP is not set\n# CONFIG_RELAY is not set\n# CONFIG_BLK_DEV_INITRD is not set\n# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set\nCONFIG_ANON_INODES=y\nCONFIG_HAVE_UID16=y\nCONFIG_SYSCTL_EXCEPTION_TRACE=y\nCONFIG_HAVE_PCSPKR_PLATFORM=y\nCONFIG_EXPERT=y\n# CONFIG_MULTIUSER is not set\n# CONFIG_SGETMASK_SYSCALL is not set\n# CONFIG_SYSFS_SYSCALL is not set\n# CONFIG_KALLSYMS is not set\nCONFIG_PRINTK=y\n# CONFIG_BUG is not set\n# CONFIG_PCSPKR_PLATFORM is not set\n# CONFIG_BASE_FULL is not set\n# CONFIG_FUTEX is not set\n# CONFIG_EPOLL is not set\n# CONFIG_SIGNALFD is not set\n# CONFIG_TIMERFD is not set\n# CONFIG_EVENTFD is not set\n# CONFIG_BPF_SYSCALL is not set\n# CONFIG_SHMEM is not set\n# CONFIG_AIO is not set\n# CONFIG_ADVISE_SYSCALLS is not set\n# CONFIG_EMBEDDED is not set\nCONFIG_HAVE_PERF_EVENTS=y\n\n#\n# Kernel Performance Events And Counters\n#\nCONFIG_PERF_EVENTS=y\n# CONFIG_DEBUG_PERF_USE_VMALLOC is not set\n# CONFIG_VM_EVENT_COUNTERS is not set\nCONFIG_COMPAT_BRK=y\n# CONFIG_SLAB is not set\n# CONFIG_SLUB is not set\nCONFIG_SLOB=y\n# CONFIG_PROFILING is not set\nCONFIG_HAVE_OPROFILE=y\nCONFIG_OPROFILE_NMI_TIMER=y\n# CONFIG_JUMP_LABEL is not set\n# CONFIG_UPROBES is not set\n# CONFIG_HAVE_64BIT_ALIGNED_ACCESS is not set\nCONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS=y\nCONFIG_ARCH_USE_BUILTIN_BSWAP=y\nCONFIG_HAVE_IOREMAP_PROT=y\nCONFIG_HAVE_KPROBES=y\nCONFIG_HAVE_KRETPROBES=y\nCONFIG_HAVE_OPTPROBES=y\nCONFIG_HAVE_KPROBES_ON_FTRACE=y\nCONFIG_HAVE_ARCH_TRACEHOOK=y\nCONFIG_HAVE_DMA_ATTRS=y\nCONFIG_HAVE_DMA_CONTIGUOUS=y\nCONFIG_GENERIC_SMP_IDLE_THREAD=y\nCONFIG_HAVE_REGS_AND_STACK_ACCESS_API=y\nCONFIG_HAVE_DMA_API_DEBUG=y\nCONFIG_HAVE_HW_BREAKPOINT=y\nCONFIG_HAVE_MIXED_BREAKPOINTS_REGS=y\nCONFIG_HAVE_USER_RETURN_NOTIFIER=y\nCONFIG_HAVE_PERF_EVENTS_NMI=y\nCONFIG_HAVE_PERF_REGS=y\nCONFIG_HAVE_PERF_USER_STACK_DUMP=y\nCONFIG_HAVE_ARCH_JUMP_LABEL=y\nCONFIG_ARCH_HAVE_NMI_SAFE_CMPXCHG=y\nCONFIG_HAVE_CMPXCHG_LOCAL=y\nCONFIG_HAVE_CMPXCHG_DOUBLE=y\nCONFIG_ARCH_WANT_IPC_PARSE_VERSION=y\nCONFIG_HAVE_ARCH_SECCOMP_FILTER=y\nCONFIG_HAVE_CC_STACKPROTECTOR=y\n# CONFIG_CC_STACKPROTECTOR is not set\nCONFIG_CC_STACKPROTECTOR_NONE=y\n# CONFIG_CC_STACKPROTECTOR_REGULAR is not set\n# CONFIG_CC_STACKPROTECTOR_STRONG is not set\nCONFIG_HAVE_IRQ_TIME_ACCOUNTING=y\nCONFIG_HAVE_ARCH_TRANSPARENT_HUGEPAGE=y\nCONFIG_MODULES_USE_ELF_REL=y\nCONFIG_ARCH_HAS_ELF_RANDOMIZE=y\nCONFIG_CLONE_BACKWARDS=y\nCONFIG_OLD_SIGSUSPEND3=y\nCONFIG_OLD_SIGACTION=y\n\n#\n# GCOV-based kernel profiling\n#\nCONFIG_ARCH_HAS_GCOV_PROFILE_ALL=y\nCONFIG_HAVE_GENERIC_DMA_COHERENT=y\nCONFIG_BASE_SMALL=1\n# CONFIG_MODULES is not set\n# CONFIG_BLOCK is not set\nCONFIG_INLINE_SPIN_UNLOCK_IRQ=y\nCONFIG_INLINE_READ_UNLOCK=y\nCONFIG_INLINE_READ_UNLOCK_IRQ=y\nCONFIG_INLINE_WRITE_UNLOCK=y\nCONFIG_INLINE_WRITE_UNLOCK_IRQ=y\nCONFIG_ARCH_SUPPORTS_ATOMIC_RMW=y\nCONFIG_ARCH_USE_QUEUE_RWLOCK=y\n# CONFIG_FREEZER is not set\n\n#\n# Processor type and features\n#\n# CONFIG_ZONE_DMA is not set\n# CONFIG_SMP is not set\nCONFIG_X86_FEATURE_NAMES=y\n# CONFIG_X86_EXTENDED_PLATFORM is not set\n# CONFIG_X86_32_IRIS is not set\n# CONFIG_SCHED_OMIT_FRAME_POINTER is not set\n# CONFIG_HYPERVISOR_GUEST is not set\nCONFIG_NO_BOOTMEM=y\n# CONFIG_M486 is not set\n# CONFIG_M586 is not set\n# CONFIG_M586TSC is not set\n# CONFIG_M586MMX is not set\nCONFIG_M686=y\n# CONFIG_MPENTIUMII is not set\n# CONFIG_MPENTIUMIII is not set\n# CONFIG_MPENTIUMM is not set\n# CONFIG_MPENTIUM4 is not set\n# CONFIG_MK6 is not set\n# CONFIG_MK7 is not set\n# CONFIG_MK8 is not set\n# CONFIG_MCRUSOE is not set\n# CONFIG_MEFFICEON is not set\n# CONFIG_MWINCHIPC6 is not set\n# CONFIG_MWINCHIP3D is not set\n# CONFIG_MELAN is not set\n# CONFIG_MGEODEGX1 is not set\n# CONFIG_MGEODE_LX is not set\n# CONFIG_MCYRIXIII is not set\n# CONFIG_MVIAC3_2 is not set\n# CONFIG_MVIAC7 is not set\n# CONFIG_MCORE2 is not set\n# CONFIG_MATOM is not set\nCONFIG_X86_GENERIC=y\nCONFIG_X86_INTERNODE_CACHE_SHIFT=6\nCONFIG_X86_L1_CACHE_SHIFT=6\n# CONFIG_X86_PPRO_FENCE is not set\nCONFIG_X86_INTEL_USERCOPY=y\nCONFIG_X86_USE_PPRO_CHECKSUM=y\nCONFIG_X86_TSC=y\nCONFIG_X86_CMPXCHG64=y\nCONFIG_X86_CMOV=y\nCONFIG_X86_MINIMUM_CPU_FAMILY=5\nCONFIG_X86_DEBUGCTLMSR=y\n# CONFIG_PROCESSOR_SELECT is not set\nCONFIG_CPU_SUP_INTEL=y\nCONFIG_CPU_SUP_CYRIX_32=y\nCONFIG_CPU_SUP_AMD=y\nCONFIG_CPU_SUP_CENTAUR=y\nCONFIG_CPU_SUP_TRANSMETA_32=y\nCONFIG_CPU_SUP_UMC_32=y\n# CONFIG_HPET_TIMER is not set\n# CONFIG_DMI is not set\nCONFIG_NR_CPUS=1\nCONFIG_PREEMPT_NONE=y\n# CONFIG_PREEMPT_VOLUNTARY is not set\n# CONFIG_PREEMPT is not set\n# CONFIG_X86_UP_APIC is not set\n# CONFIG_X86_MCE is not set\n# CONFIG_VM86 is not set\n# CONFIG_X86_16BIT is not set\n# CONFIG_TOSHIBA is not set\n# CONFIG_I8K is not set\n# CONFIG_X86_REBOOTFIXUPS is not set\n# CONFIG_MICROCODE is not set\n# CONFIG_X86_MSR is not set\n# CONFIG_X86_CPUID is not set\nCONFIG_NOHIGHMEM=y\n# CONFIG_HIGHMEM4G is not set\n# CONFIG_HIGHMEM64G is not set\nCONFIG_VMSPLIT_3G=y\n# CONFIG_VMSPLIT_3G_OPT is not set\n# CONFIG_VMSPLIT_2G is not set\n# CONFIG_VMSPLIT_2G_OPT is not set\n# CONFIG_VMSPLIT_1G is not set\nCONFIG_PAGE_OFFSET=0xC0000000\n# CONFIG_X86_PAE is not set\nCONFIG_ARCH_FLATMEM_ENABLE=y\nCONFIG_ARCH_SPARSEMEM_ENABLE=y\nCONFIG_ARCH_SELECT_MEMORY_MODEL=y\nCONFIG_ILLEGAL_POINTER_VALUE=0\nCONFIG_SELECT_MEMORY_MODEL=y\nCONFIG_FLATMEM_MANUAL=y\n# CONFIG_SPARSEMEM_MANUAL is not set\nCONFIG_FLATMEM=y\nCONFIG_FLAT_NODE_MEM_MAP=y\nCONFIG_SPARSEMEM_STATIC=y\nCONFIG_HAVE_MEMBLOCK=y\nCONFIG_HAVE_MEMBLOCK_NODE_MAP=y\nCONFIG_ARCH_DISCARD_MEMBLOCK=y\n# CONFIG_HAVE_BOOTMEM_INFO_NODE is not set\nCONFIG_PAGEFLAGS_EXTENDED=y\nCONFIG_SPLIT_PTLOCK_CPUS=4\n# CONFIG_COMPACTION is not set\n# CONFIG_PHYS_ADDR_T_64BIT is not set\nCONFIG_ZONE_DMA_FLAG=0\nCONFIG_VIRT_TO_BUS=y\n# CONFIG_KSM is not set\nCONFIG_DEFAULT_MMAP_MIN_ADDR=4096\n# CONFIG_TRANSPARENT_HUGEPAGE is not set\nCONFIG_NEED_PER_CPU_KM=y\n# CONFIG_CLEANCACHE is not set\n# CONFIG_CMA is not set\n# CONFIG_ZPOOL is not set\n# CONFIG_ZBUD is not set\n# CONFIG_ZSMALLOC is not set\nCONFIG_GENERIC_EARLY_IOREMAP=y\n# CONFIG_X86_PMEM_LEGACY is not set\n# CONFIG_X86_CHECK_BIOS_CORRUPTION is not set\nCONFIG_X86_RESERVE_LOW=64\n# CONFIG_MATH_EMULATION is not set\n# CONFIG_MTRR is not set\n# CONFIG_ARCH_RANDOM is not set\n# CONFIG_X86_SMAP is not set\n# CONFIG_X86_INTEL_MPX is not set\n# CONFIG_SECCOMP is not set\n# CONFIG_HZ_100 is not set\n# CONFIG_HZ_250 is not set\n# CONFIG_HZ_300 is not set\nCONFIG_HZ_1000=y\nCONFIG_HZ=1000\nCONFIG_SCHED_HRTICK=y\n# CONFIG_KEXEC is not set\nCONFIG_PHYSICAL_START=0x1000000\n# CONFIG_RELOCATABLE is not set\nCONFIG_PHYSICAL_ALIGN=0x200000\n# CONFIG_COMPAT_VDSO is not set\n# CONFIG_CMDLINE_BOOL is not set\n\n#\n# Power management and ACPI options\n#\n# CONFIG_SUSPEND is not set\n# CONFIG_PM is not set\n# CONFIG_SFI is not set\n\n#\n# CPU Frequency scaling\n#\n# CONFIG_CPU_FREQ is not set\n\n#\n# CPU Idle\n#\n# CONFIG_CPU_IDLE is not set\n# CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED is not set\n\n#\n# Bus options (PCI etc.)\n#\n# CONFIG_PCI is not set\nCONFIG_ISA_DMA_API=y\n# CONFIG_ISA is not set\n# CONFIG_SCx200 is not set\n# CONFIG_OLPC is not set\n# CONFIG_ALIX is not set\n# CONFIG_NET5501 is not set\n# CONFIG_PCCARD is not set\n# CONFIG_X86_SYSFB is not set\n\n#\n# Executable file formats / Emulations\n#\n# CONFIG_BINFMT_ELF is not set\n# CONFIG_BINFMT_SCRIPT is not set\nCONFIG_HAVE_AOUT=y\n# CONFIG_BINFMT_AOUT is not set\n# CONFIG_BINFMT_MISC is not set\n# CONFIG_COREDUMP is not set\nCONFIG_HAVE_ATOMIC_IOMAP=y\n# CONFIG_NET is not set\n\n#\n# Device Drivers\n#\n\n#\n# Generic Driver Options\n#\n# CONFIG_UEVENT_HELPER is not set\n# CONFIG_DEVTMPFS is not set\n# CONFIG_STANDALONE is not set\n# CONFIG_PREVENT_FIRMWARE_BUILD is not set\n# CONFIG_FW_LOADER is not set\n# CONFIG_ALLOW_DEV_COREDUMP is not set\n# CONFIG_DEBUG_DRIVER is not set\n# CONFIG_DEBUG_DEVRES is not set\n# CONFIG_SYS_HYPERVISOR is not set\n# CONFIG_GENERIC_CPU_DEVICES is not set\nCONFIG_GENERIC_CPU_AUTOPROBE=y\n# CONFIG_DMA_SHARED_BUFFER is not set\n\n#\n# Bus devices\n#\n# CONFIG_MTD is not set\nCONFIG_ARCH_MIGHT_HAVE_PC_PARPORT=y\n# CONFIG_PARPORT is not set\n\n#\n# Misc devices\n#\n# CONFIG_SENSORS_LIS3LV02D is not set\n# CONFIG_DUMMY_IRQ is not set\n# CONFIG_ENCLOSURE_SERVICES is not set\n# CONFIG_SRAM is not set\n# CONFIG_C2PORT is not set\n\n#\n# EEPROM support\n#\n# CONFIG_EEPROM_93CX6 is not set\n\n#\n# Texas Instruments shared transport line discipline\n#\n\n#\n# Altera FPGA firmware download module\n#\n\n#\n# Intel MIC Bus Driver\n#\n\n#\n# Intel MIC Host Driver\n#\n\n#\n# Intel MIC Card Driver\n#\n# CONFIG_ECHO is not set\n# CONFIG_CXL_BASE is not set\nCONFIG_HAVE_IDE=y\n\n#\n# SCSI device support\n#\nCONFIG_SCSI_MOD=y\n# CONFIG_SCSI_DMA is not set\n# CONFIG_MACINTOSH_DRIVERS is not set\n\n#\n# Input device support\n#\nCONFIG_INPUT=y\n# CONFIG_INPUT_FF_MEMLESS is not set\n# CONFIG_INPUT_POLLDEV is not set\n# CONFIG_INPUT_SPARSEKMAP is not set\n# CONFIG_INPUT_MATRIXKMAP is not set\n\n#\n# Userland interfaces\n#\n# CONFIG_INPUT_MOUSEDEV is not set\n# CONFIG_INPUT_JOYDEV is not set\n# CONFIG_INPUT_EVDEV is not set\n# CONFIG_INPUT_EVBUG is not set\n\n#\n# Input Device Drivers\n#\n# CONFIG_INPUT_KEYBOARD is not set\n# CONFIG_INPUT_MOUSE is not set\n# CONFIG_INPUT_JOYSTICK is not set\n# CONFIG_INPUT_TABLET is not set\n# CONFIG_INPUT_TOUCHSCREEN is not set\n# CONFIG_INPUT_MISC is not set\n\n#\n# Hardware I/O ports\n#\n# CONFIG_SERIO is not set\nCONFIG_ARCH_MIGHT_HAVE_PC_SERIO=y\n# CONFIG_GAMEPORT is not set\n\n#\n# Character devices\n#\nCONFIG_TTY=y\nCONFIG_VT=y\n# CONFIG_CONSOLE_TRANSLATIONS is not set\nCONFIG_VT_CONSOLE=y\nCONFIG_HW_CONSOLE=y\n# CONFIG_VT_HW_CONSOLE_BINDING is not set\n# CONFIG_UNIX98_PTYS is not set\n# CONFIG_LEGACY_PTYS is not set\n# CONFIG_SERIAL_NONSTANDARD is not set\n# CONFIG_TRACE_SINK is not set\n# CONFIG_DEVMEM is not set\n# CONFIG_DEVKMEM is not set\n\n#\n# Serial drivers\n#\n# CONFIG_SERIAL_8250 is not set\n\n#\n# Non-8250 serial port support\n#\n# CONFIG_SERIAL_SCCNXP is not set\n# CONFIG_SERIAL_TIMBERDALE is not set\n# CONFIG_SERIAL_ALTERA_JTAGUART is not set\n# CONFIG_SERIAL_ALTERA_UART is not set\n# CONFIG_SERIAL_ARC is not set\n# CONFIG_SERIAL_FSL_LPUART is not set\n# CONFIG_TTY_PRINTK is not set\n# CONFIG_IPMI_HANDLER is not set\n# CONFIG_HW_RANDOM is not set\n# CONFIG_NVRAM is not set\n# CONFIG_R3964 is not set\n# CONFIG_MWAVE is not set\n# CONFIG_PC8736x_GPIO is not set\n# CONFIG_NSC_GPIO is not set\n# CONFIG_HANGCHECK_TIMER is not set\n# CONFIG_TCG_TPM is not set\n# CONFIG_TELCLOCK is not set\n\n#\n# I2C support\n#\n# CONFIG_I2C is not set\n# CONFIG_SPI is not set\n# CONFIG_SPMI is not set\n# CONFIG_HSI is not set\n\n#\n# PPS support\n#\n# CONFIG_PPS is not set\n\n#\n# PPS generators support\n#\n\n#\n# PTP clock support\n#\n\n#\n# Enable PHYLIB and NETWORK_PHY_TIMESTAMPING to see the additional clocks.\n#\nCONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y\n# CONFIG_GPIOLIB is not set\n# CONFIG_W1 is not set\n# CONFIG_POWER_SUPPLY is not set\n# CONFIG_POWER_AVS is not set\n# CONFIG_HWMON is not set\n# CONFIG_THERMAL is not set\n# CONFIG_WATCHDOG is not set\nCONFIG_SSB_POSSIBLE=y\n\n#\n# Sonics Silicon Backplane\n#\n# CONFIG_SSB is not set\nCONFIG_BCMA_POSSIBLE=y\n\n#\n# Broadcom specific AMBA\n#\n# CONFIG_BCMA is not set\n\n#\n# Multifunction device drivers\n#\n# CONFIG_MFD_CORE is not set\n# CONFIG_MFD_CROS_EC is not set\n# CONFIG_HTC_PASIC3 is not set\n# CONFIG_MFD_KEMPLD is not set\n# CONFIG_MFD_MT6397 is not set\n# CONFIG_MFD_SM501 is not set\n# CONFIG_ABX500_CORE is not set\n# CONFIG_MFD_SYSCON is not set\n# CONFIG_MFD_TI_AM335X_TSCADC is not set\n# CONFIG_MFD_TMIO is not set\n# CONFIG_REGULATOR is not set\n# CONFIG_MEDIA_SUPPORT is not set\n\n#\n# Graphics support\n#\n\n#\n# Direct Rendering Manager\n#\n# CONFIG_DRM is not set\n\n#\n# Frame buffer Devices\n#\n# CONFIG_FB is not set\n# CONFIG_BACKLIGHT_LCD_SUPPORT is not set\n# CONFIG_VGASTATE is not set\n\n#\n# Console display driver support\n#\nCONFIG_VGA_CONSOLE=y\n# CONFIG_VGACON_SOFT_SCROLLBACK is not set\nCONFIG_DUMMY_CONSOLE=y\nCONFIG_DUMMY_CONSOLE_COLUMNS=80\nCONFIG_DUMMY_CONSOLE_ROWS=25\n# CONFIG_SOUND is not set\n\n#\n# HID support\n#\n# CONFIG_HID is not set\nCONFIG_USB_OHCI_LITTLE_ENDIAN=y\n# CONFIG_USB_SUPPORT is not set\n# CONFIG_UWB is not set\n# CONFIG_MMC is not set\n# CONFIG_MEMSTICK is not set\n# CONFIG_NEW_LEDS is not set\n# CONFIG_ACCESSIBILITY is not set\n# CONFIG_EDAC is not set\nCONFIG_RTC_LIB=y\n# CONFIG_RTC_CLASS is not set\n# CONFIG_DMADEVICES is not set\n# CONFIG_AUXDISPLAY is not set\n# CONFIG_UIO is not set\n# CONFIG_VIRT_DRIVERS is not set\n\n#\n# Virtio drivers\n#\n# CONFIG_VIRTIO_MMIO is not set\n\n#\n# Microsoft Hyper-V guest support\n#\n# CONFIG_STAGING is not set\n# CONFIG_X86_PLATFORM_DEVICES is not set\n# CONFIG_CHROME_PLATFORMS is not set\n\n#\n# Hardware Spinlock drivers\n#\n\n#\n# Clock Source drivers\n#\nCONFIG_CLKSRC_I8253=y\nCONFIG_CLKEVT_I8253=y\nCONFIG_CLKBLD_I8253=y\n# CONFIG_ATMEL_PIT is not set\n# CONFIG_SH_TIMER_CMT is not set\n# CONFIG_SH_TIMER_MTU2 is not set\n# CONFIG_SH_TIMER_TMU is not set\n# CONFIG_EM_TIMER_STI is not set\n# CONFIG_MAILBOX is not set\n# CONFIG_IOMMU_SUPPORT is not set\n\n#\n# Remoteproc drivers\n#\n# CONFIG_STE_MODEM_RPROC is not set\n\n#\n# Rpmsg drivers\n#\n\n#\n# SOC (System On Chip) specific Drivers\n#\n# CONFIG_SOC_TI is not set\n# CONFIG_PM_DEVFREQ is not set\n# CONFIG_EXTCON is not set\n# CONFIG_MEMORY is not set\n# CONFIG_IIO is not set\n# CONFIG_PWM is not set\n# CONFIG_IPACK_BUS is not set\n# CONFIG_RESET_CONTROLLER is not set\n# CONFIG_FMC is not set\n\n#\n# PHY Subsystem\n#\n# CONFIG_GENERIC_PHY is not set\n# CONFIG_BCM_KONA_USB2_PHY is not set\n# CONFIG_POWERCAP is not set\n# CONFIG_MCB is not set\n\n#\n# Android\n#\n# CONFIG_ANDROID is not set\n\n#\n# Firmware Drivers\n#\n# CONFIG_EDD is not set\n# CONFIG_FIRMWARE_MEMMAP is not set\n# CONFIG_DELL_RBU is not set\n# CONFIG_DCDBAS is not set\n# CONFIG_GOOGLE_FIRMWARE is not set\n\n#\n# File systems\n#\nCONFIG_DCACHE_WORD_ACCESS=y\n# CONFIG_FS_POSIX_ACL is not set\n# CONFIG_FILE_LOCKING is not set\n# CONFIG_FSNOTIFY is not set\n# CONFIG_DNOTIFY is not set\n# CONFIG_INOTIFY_USER is not set\n# CONFIG_FANOTIFY is not set\n# CONFIG_QUOTA is not set\n# CONFIG_QUOTACTL is not set\n# CONFIG_AUTOFS4_FS is not set\n# CONFIG_FUSE_FS is not set\n# CONFIG_OVERLAY_FS is not set\n\n#\n# Caches\n#\n# CONFIG_FSCACHE is not set\n\n#\n# Pseudo filesystems\n#\n# CONFIG_PROC_FS is not set\n# CONFIG_KERNFS is not set\n# CONFIG_SYSFS is not set\n# CONFIG_HUGETLBFS is not set\n# CONFIG_HUGETLB_PAGE is not set\n# CONFIG_CONFIGFS_FS is not set\n# CONFIG_MISC_FILESYSTEMS is not set\n# CONFIG_NLS is not set\n\n#\n# Kernel hacking\n#\nCONFIG_TRACE_IRQFLAGS_SUPPORT=y\n\n#\n# printk and dmesg options\n#\nCONFIG_PRINTK_TIME=y\nCONFIG_MESSAGE_LOGLEVEL_DEFAULT=4\n# CONFIG_BOOT_PRINTK_DELAY is not set\n\n#\n# Compile-time checks and compiler options\n#\n# CONFIG_DEBUG_INFO is not set\n# CONFIG_ENABLE_WARN_DEPRECATED is not set\n# CONFIG_ENABLE_MUST_CHECK is not set\nCONFIG_FRAME_WARN=2048\n# CONFIG_STRIP_ASM_SYMS is not set\n# CONFIG_READABLE_ASM is not set\n# CONFIG_UNUSED_SYMBOLS is not set\n# CONFIG_PAGE_OWNER is not set\n# CONFIG_DEBUG_FS is not set\n# CONFIG_HEADERS_CHECK is not set\n# CONFIG_DEBUG_SECTION_MISMATCH is not set\nCONFIG_ARCH_WANT_FRAME_POINTERS=y\nCONFIG_FRAME_POINTER=y\n# CONFIG_DEBUG_FORCE_WEAK_PER_CPU is not set\n# CONFIG_MAGIC_SYSRQ is not set\nCONFIG_DEBUG_KERNEL=y\n\n#\n# Memory Debugging\n#\n# CONFIG_PAGE_EXTENSION is not set\n# CONFIG_DEBUG_PAGEALLOC is not set\n# CONFIG_DEBUG_OBJECTS is not set\nCONFIG_HAVE_DEBUG_KMEMLEAK=y\n# CONFIG_DEBUG_KMEMLEAK is not set\n# CONFIG_DEBUG_STACK_USAGE is not set\n# CONFIG_DEBUG_VM is not set\n# CONFIG_DEBUG_VIRTUAL is not set\n# CONFIG_DEBUG_MEMORY_INIT is not set\nCONFIG_HAVE_DEBUG_STACKOVERFLOW=y\n# CONFIG_DEBUG_STACKOVERFLOW is not set\nCONFIG_HAVE_ARCH_KMEMCHECK=y\n# CONFIG_DEBUG_SHIRQ is not set\n\n#\n# Debug Lockups and Hangs\n#\n# CONFIG_LOCKUP_DETECTOR is not set\n# CONFIG_DETECT_HUNG_TASK is not set\n# CONFIG_PANIC_ON_OOPS is not set\nCONFIG_PANIC_ON_OOPS_VALUE=0\nCONFIG_PANIC_TIMEOUT=0\n# CONFIG_SCHED_STACK_END_CHECK is not set\n# CONFIG_DEBUG_TIMEKEEPING is not set\n\n#\n# Lock Debugging (spinlocks, mutexes, etc...)\n#\n# CONFIG_DEBUG_SPINLOCK is not set\n# CONFIG_DEBUG_MUTEXES is not set\n# CONFIG_DEBUG_WW_MUTEX_SLOWPATH is not set\n# CONFIG_DEBUG_LOCK_ALLOC is not set\n# CONFIG_PROVE_LOCKING is not set\n# CONFIG_LOCK_STAT is not set\n# CONFIG_DEBUG_ATOMIC_SLEEP is not set\n# CONFIG_DEBUG_LOCKING_API_SELFTESTS is not set\n# CONFIG_LOCK_TORTURE_TEST is not set\n# CONFIG_STACKTRACE is not set\n# CONFIG_DEBUG_KOBJECT is not set\n# CONFIG_DEBUG_LIST is not set\n# CONFIG_DEBUG_PI_LIST is not set\n# CONFIG_DEBUG_SG is not set\n# CONFIG_DEBUG_NOTIFIERS is not set\n# CONFIG_DEBUG_CREDENTIALS is not set\n\n#\n# RCU Debugging\n#\n# CONFIG_PROVE_RCU is not set\n# CONFIG_SPARSE_RCU_POINTER is not set\n# CONFIG_TORTURE_TEST is not set\n# CONFIG_RCU_TORTURE_TEST is not set\n# CONFIG_RCU_TRACE is not set\n# CONFIG_NOTIFIER_ERROR_INJECTION is not set\n# CONFIG_FAULT_INJECTION is not set\nCONFIG_ARCH_HAS_DEBUG_STRICT_USER_COPY_CHECKS=y\n# CONFIG_DEBUG_STRICT_USER_COPY_CHECKS is not set\nCONFIG_USER_STACKTRACE_SUPPORT=y\nCONFIG_HAVE_FUNCTION_TRACER=y\nCONFIG_HAVE_FUNCTION_GRAPH_TRACER=y\nCONFIG_HAVE_FUNCTION_GRAPH_FP_TEST=y\nCONFIG_HAVE_DYNAMIC_FTRACE=y\nCONFIG_HAVE_DYNAMIC_FTRACE_WITH_REGS=y\nCONFIG_HAVE_FTRACE_MCOUNT_RECORD=y\nCONFIG_HAVE_SYSCALL_TRACEPOINTS=y\nCONFIG_HAVE_C_RECORDMCOUNT=y\nCONFIG_TRACING_SUPPORT=y\n# CONFIG_FTRACE is not set\n\n#\n# Runtime Testing\n#\n# CONFIG_TEST_LIST_SORT is not set\n# CONFIG_BACKTRACE_SELF_TEST is not set\n# CONFIG_RBTREE_TEST is not set\n# CONFIG_ATOMIC64_SELFTEST is not set\n# CONFIG_TEST_HEXDUMP is not set\n# CONFIG_TEST_STRING_HELPERS is not set\n# CONFIG_TEST_KSTRTOX is not set\n# CONFIG_TEST_RHASHTABLE is not set\n# CONFIG_DMA_API_DEBUG is not set\n# CONFIG_TEST_UDELAY is not set\n# CONFIG_MEMTEST is not set\n# CONFIG_SAMPLES is not set\nCONFIG_HAVE_ARCH_KGDB=y\n# CONFIG_KGDB is not set\n# CONFIG_STRICT_DEVMEM is not set\nCONFIG_X86_VERBOSE_BOOTUP=y\nCONFIG_EARLY_PRINTK=y\n# CONFIG_X86_PTDUMP is not set\n# CONFIG_DEBUG_RODATA is not set\n# CONFIG_DOUBLEFAULT is not set\n# CONFIG_DEBUG_TLBFLUSH is not set\n# CONFIG_IOMMU_STRESS is not set\nCONFIG_HAVE_MMIOTRACE_SUPPORT=y\nCONFIG_IO_DELAY_TYPE_0X80=0\nCONFIG_IO_DELAY_TYPE_0XED=1\nCONFIG_IO_DELAY_TYPE_UDELAY=2\nCONFIG_IO_DELAY_TYPE_NONE=3\nCONFIG_IO_DELAY_0X80=y\n# CONFIG_IO_DELAY_0XED is not set\n# CONFIG_IO_DELAY_UDELAY is not set\n# CONFIG_IO_DELAY_NONE is not set\nCONFIG_DEFAULT_IO_DELAY_TYPE=0\n# CONFIG_CPA_DEBUG is not set\n# CONFIG_OPTIMIZE_INLINING is not set\n# CONFIG_X86_DEBUG_STATIC_CPU_HAS is not set\n\n#\n# Security options\n#\n# CONFIG_KEYS is not set\n# CONFIG_SECURITY_DMESG_RESTRICT is not set\n# CONFIG_SECURITYFS is not set\nCONFIG_DEFAULT_SECURITY_DAC=y\nCONFIG_DEFAULT_SECURITY=\"\"\n# CONFIG_CRYPTO is not set\nCONFIG_HAVE_KVM=y\n# CONFIG_VIRTUALIZATION is not set\n# CONFIG_BINARY_PRINTF is not set\n\n#\n# Library routines\n#\nCONFIG_GENERIC_STRNCPY_FROM_USER=y\nCONFIG_GENERIC_STRNLEN_USER=y\nCONFIG_GENERIC_FIND_FIRST_BIT=y\nCONFIG_GENERIC_PCI_IOMAP=y\nCONFIG_GENERIC_IOMAP=y\nCONFIG_GENERIC_IO=y\nCONFIG_ARCH_HAS_FAST_MULTIPLIER=y\n# CONFIG_CRC_CCITT is not set\n# CONFIG_CRC16 is not set\n# CONFIG_CRC_T10DIF is not set\n# CONFIG_CRC_ITU_T is not set\n# CONFIG_CRC32 is not set\n# CONFIG_CRC7 is not set\n# CONFIG_LIBCRC32C is not set\n# CONFIG_CRC8 is not set\n# CONFIG_AUDIT_ARCH_COMPAT_GENERIC is not set\n# CONFIG_RANDOM32_SELFTEST is not set\n# CONFIG_XZ_DEC is not set\n# CONFIG_XZ_DEC_BCJ is not set\nCONFIG_HAS_IOMEM=y\nCONFIG_HAS_IOPORT_MAP=y\nCONFIG_HAS_DMA=y\nCONFIG_ARCH_HAS_ATOMIC64_DEC_IF_POSITIVE=y\n# CONFIG_AVERAGE is not set\n# CONFIG_CORDIC is not set\n# CONFIG_DDR is not set\nCONFIG_ARCH_HAS_SG_CHAIN=y\n"
  },
  {
    "path": "patches/linux-4_1-mykernel.patch",
    "content": "diff --git a/Makefile b/Makefile\nindex f5c8983..0cfa80d 100644\n--- a/Makefile\n+++ b/Makefile\n@@ -883,7 +883,7 @@ export mod_sign_cmd\n \n \n ifeq ($(KBUILD_EXTMOD),)\n-core-y\t\t+= kernel/ mm/ fs/ ipc/ security/ crypto/ block/\n+core-y\t\t+= kernel/ mm/ fs/ ipc/ security/ crypto/ block/ mysrc/\n \n vmlinux-dirs\t:= $(patsubst %/,%,$(filter %/, $(init-y) $(init-m) \\\n \t\t     $(core-y) $(core-m) $(drivers-y) $(drivers-m) \\\ndiff --git a/arch/x86/kernel/time.c b/arch/x86/kernel/time.c\nindex d39c091..28d1af5 100644\n--- a/arch/x86/kernel/time.c\n+++ b/arch/x86/kernel/time.c\n@@ -57,6 +57,7 @@ EXPORT_SYMBOL(profile_pc);\n static irqreturn_t timer_interrupt(int irq, void *dev_id)\n {\n \tglobal_clock_event->event_handler(global_clock_event);\n+\tmy_timer_handler();\n \treturn IRQ_HANDLED;\n }\n \n@@ -68,6 +69,7 @@ static struct irqaction irq0  = {\n \n void __init setup_default_timer_irq(void)\n {\n+\tprintk(KERN_NOTICE \"timer interrupt setup\\n\");\n \tif (!nr_legacy_irqs())\n \t\treturn;\n \tsetup_irq(0, &irq0);\ndiff --git a/include/linux/start_kernel.h b/include/linux/start_kernel.h\nindex d3e5f27..9004b44 100644\n--- a/include/linux/start_kernel.h\n+++ b/include/linux/start_kernel.h\n@@ -8,5 +8,6 @@\n    up something else. */\n \n extern asmlinkage void __init start_kernel(void);\n+extern void __init my_start_kernel(void);\n \n #endif /* _LINUX_START_KERNEL_H */\ndiff --git a/include/linux/timer.h b/include/linux/timer.h\nindex 8c5a197..d22e9c0 100644\n--- a/include/linux/timer.h\n+++ b/include/linux/timer.h\n@@ -251,6 +251,8 @@ extern int try_to_del_timer_sync(struct timer_list *timer);\n \n extern void init_timers(void);\n extern void run_local_timers(void);\n+extern void my_timer_handler(void);\n+\n struct hrtimer;\n extern enum hrtimer_restart it_real_fn(struct hrtimer *);\n \ndiff --git a/init/main.c b/init/main.c\nindex 2115055..d93a869 100644\n--- a/init/main.c\n+++ b/init/main.c\n@@ -673,6 +673,7 @@ asmlinkage __visible void __init start_kernel(void)\n \n \tftrace_init();\n \n+\tmy_start_kernel();\n \t/* Do the rest non-__init'ed, we're now alive */\n \trest_init();\n }\n"
  },
  {
    "path": "src/Makefile",
    "content": "# used by Linux kernel\nobj-y = \\\n\tmain.o \\\n\tscheduler.o\n"
  },
  {
    "path": "src/main.c",
    "content": "#include <linux/printk.h>\n\n#include \"mypcb.h\"\n\nmyPCB task[MAX_TASK_NUM], *my_current_task = NULL;\nvolatile int my_need_sched = 0;\n\nstatic void my_process(void);\n\nvoid __init my_start_kernel(void)\n{\n\tint pid = 0;\n\tint i;\n\n\t/* Initialize process 0 */\n\ttask[pid].pid = pid;\n\ttask[pid].state = S_runnable;\n\ttask[pid].task_entry = task[pid].thread.ip = (uintptr_t) my_process;\n\ttask[pid].thread.sp =\n\t\t(uintptr_t) &task[pid].stack[KERNEL_STACK_SIZE - 1];\n\ttask[pid].next = &task[pid];\n\n\t/* fork more process */\n\tfor (i = 1; i < MAX_TASK_NUM; i++) {\n\t\tmemcpy(&task[i], &task[0], sizeof(myPCB));\n\t\ttask[i].pid = i;\n\t\ttask[i].state = S_stopped;\n\t\ttask[i].thread.sp =\n\t\t\t(uintptr_t) &task[i].stack[KERNEL_STACK_SIZE - 1];\n\t\ttask[i].next = task[i-1].next;\n\t\ttask[i-1].next = &task[i];\n\t}\n\n\t/* start process 0 by task[0] */\n\tpid = 0;\n\tmy_current_task = &task[pid];\n\tasm volatile(\n\t\t\"movl\t%0, %%esp\\n\\t\" \t/* set task[pid].thread.sp to esp */\n\t\t\"jmp\tmy_process\\n\"\n\t\t: \n\t\t: \"c\" (task[pid].thread.sp)\t/* input c mean /%edx */\n\t);\n}\n\nstatic void my_process(void)\n{\n\tint i = 0;\n\twhile (1) {\n\t\tif (i++ % 10000000)\n\t\t\tcontinue;\n\n\t\tprintk(KERN_NOTICE \"this is process %d -\\n\",\n\t\t       my_current_task->pid);\n\t\tif (my_need_sched == 1) {\n\t\t\tmy_need_sched = 0;\n\t\t\tmy_schedule();\n\t\t}\n\t\tprintk(KERN_NOTICE \"this is process %d +\\n\",\n\t\t       my_current_task->pid);\n\t}\n}\n"
  },
  {
    "path": "src/mypcb.h",
    "content": "#include <linux/types.h>\n\n#define MAX_TASK_NUM\t\t4\n#define KERNEL_STACK_SIZE\t(1024 * 8)\n\n/* CPU-specific state of this task */\nstruct myThread {\n\tuintptr_t ip;\n\tuintptr_t sp;\n};\n\nenum myState { S_unrunnable = -1, S_runnable = 0, S_stopped = 1 };\ntypedef struct _myPCB {\n\tint pid;\n\tvolatile enum myState state;\n\tchar stack[KERNEL_STACK_SIZE];\n\t/* CPU-specific state of this task */\n\tstruct myThread thread;\n\tuintptr_t task_entry;\n\tstruct _myPCB *next;\n} myPCB;\n\nvoid my_schedule(void);\n"
  },
  {
    "path": "src/scheduler.c",
    "content": "#include <linux/printk.h>\n\n#include \"mypcb.h\"\n\nextern myPCB task[MAX_TASK_NUM], *my_current_task;\nextern volatile int my_need_sched;\nvolatile int time_count = 0;\n\n/*\n * Called by timer interrupt.\n * it runs in the name of current running process,\n * so it use kernel stack of current running process\n */\nvoid my_timer_handler(void)\n{\n\tif (time_count % 1000 == 0 && my_need_sched != 1)\n\t\tmy_need_sched = 1;\n\ttime_count++;\n}\n\nvoid my_schedule(void)\n{\n\tmyPCB *next, *prev;\n\n\tif (my_current_task == NULL || my_current_task->next == NULL)\n\t\treturn;\n\n\tprintk(KERN_NOTICE \">>> %s <<<\\n\", __func__);\n\t/* schedule */\n\tnext = my_current_task->next;\n\tprev = my_current_task;\n\tif (next->state == S_runnable) {\n\t\tmy_current_task = next;\n\t\tprintk(KERN_NOTICE \">>>switch from %d to %d<<<\\n\",\n\t\t\tprev->pid, next->pid);\n                /* switch to next process */\n\t\tasm volatile(\t\n\t\t\t\"movl\t%%esp, %0\\n\\t\"\t/* save esp */\n\t\t\t\"movl\t%2, %%esp\\n\\t\"\t/* restore  esp */\n\t\t\t\"movl\t$1f, %1\\n\\t\"\t/* save eip */\n\t\t\t\"jmp\t*%3\\n\"\n\t\t\t\"1:\\t\"\t\t\t/* next process start here */\n\t\t\t: \"=m\" (prev->thread.sp), \"=m\" (prev->thread.ip)\n\t\t\t: \"m\" (next->thread.sp), \"m\" (next->thread.ip)\n\t\t);\n\t} else {\n\t\tnext->state = S_runnable;\n\t\tmy_current_task = next;\n\t\tprintk(KERN_NOTICE \">>>switch to new process %d<<<\\n\",\n\t\t\tnext->pid);\n\t}\n}\n"
  }
]