资源简介
linux-4.16.10.tar.xz
kernel 内核 可编译
代码片段和文件信息
// SPDX-License-Identifier: GPL-2.0
/*
* arch/alpha/boot/bootp.c
*
* Copyright (C) 1997 Jay Estabrook
*
* This file is used for creating a bootp file for the Linux/AXP kernel
*
* based significantly on the arch/alpha/boot/main.c of Linus Torvalds
*/
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include “ksize.h“
extern unsigned long switch_to_osf_pal(unsigned long nr
struct pcb_struct * pcb_va struct pcb_struct * pcb_pa
unsigned long *vptb);
extern void move_stack(unsigned long new_stack);
struct hwrpb_struct *hwrpb = INIT_HWRPB;
static struct pcb_struct pcb_va[1];
/*
* Find a physical address of a virtual object..
*
* This is easy using the virtual page table address.
*/
static inline void *
find_pa(unsigned long *vptb void *ptr)
{
unsigned long address = (unsigned long) ptr;
unsigned long result;
result = vptb[address >> 13];
result >>= 32;
result <<= 13;
result |= address & 0x1fff;
return (void *) result;
}
/*
* This function moves into OSF/1 pal-code and has a temporary
* PCB for that. The kernel proper should replace this PCB with
* the real one as soon as possible.
*
* The page table muckery in here depends on the fact that the boot
* code has the L1 page table identity-map itself in the second PTE
* in the L1 page table. Thus the L1-page is virtually addressable
* itself (through three levels) at virtual address 0x200802000.
*/
#define VPTB ((unsigned long *) 0x200000000)
#define L1 ((unsigned long *) 0x200802000)
void
pal_init(void)
{
unsigned long i rev;
struct percpu_struct * percpu;
struct pcb_struct * pcb_pa;
/* Create the dummy PCB. */
pcb_va->ksp = 0;
pcb_va->usp = 0;
pcb_va->ptbr = L1[1] >> 32;
pcb_va->asn = 0;
pcb_va->pcc = 0;
pcb_va->unique = 0;
pcb_va->flags = 1;
pcb_va->res1 = 0;
pcb_va->res2 = 0;
pcb_pa = find_pa(VPTB pcb_va);
/*
* a0 = 2 (OSF)
* a1 = return address but we give the asm the vaddr of the PCB
* a2 = physical addr of PCB
* a3 = new virtual page table pointer
* a4 = KSP (but the asm sets it)
*/
srm_printk(“Switching to OSF PAL-code .. “);
i = switch_to_osf_pal(2 pcb_va pcb_pa VPTB);
if (i) {
srm_printk(“failed code %ld\n“ i);
__halt();
}
percpu = (struct percpu_struct *)
(INIT_HWRPB->processor_offset + (unsigned long) INIT_HWRPB);
rev = percpu->pal_revision = percpu->palcode_avail[2];
srm_printk(“Ok (rev %lx)\n“ rev);
tbia(); /* do it directly in case we are SMP */
}
static inline void
load(unsigned long dst unsigned long src unsigned long count)
{
memcpy((void *)dst (void *)src count);
}
/*
* Start the kernel.
*/
static inline void
runkernel(void)
{
__asm__ __volatile__(
“bis %0%0$27\n\t“
“jmp ($27)“
: /* no outputs: it doesn‘t even return */
: “r“ (START_ADDR));
}
extern char _end;
#define KER
- 上一篇:app管理系统
- 下一篇:树莓派实战指南100个案例
相关资源
- Linux内核函数Start_kernel()的功能
- Existence of Solutions to Volterra Integral Eq
- Linux Kernel Networking Implementation and The
- Learning with Kernels
- Kernel Methods for Pattern Analysis
- 内核漏洞的利用与防范A Guide to Kerne
- 《Windows内核原理与实现》wrk源码工具
- Linux4.4内核API文档
- Linux Kernel Development(3rd) 无水印原版
- PDF版深入理解Linux内核(第三版) (
- Microc-Os-Ii-The-Real-Time-Kernel
- Kernel Smoothing
- kernel-devel-3.10.0-862.14.4.el7.x86_64
- Kernel Methods and Machine Learning
- µC/OS-II: The Real-Time Kernel 2nd Edition英文
- 深入分析Linux内核源代码 陈莉君 PDF版
- 10.6.5破解内核mach_kernel
- Understanding the Linux Kernel 3rd 原版pdf
- linux内核分析及各个版本kernel源码地址
- kernel-headers-3.10.0-327.el7.x86_64.rpm
- Linux Kernel Development第三版
- An Introduction to Support Vector Machines and
- Rootkits-Subverting_the_Windows_Kernel
- petalinux编译uboot、kernel、rootfs方法
- kernel-devel-2.6.32-431.29.2.el6.x86_64.rpm
- Using the FreeRTOS Real Time Kernel - A Practi
- Windows Kernel Programming (2019).pdf
- Linux Kernel Networking: Implementation and Th
- Linux Kernel Development 3rd Edition - Robert
- EPD(EINK)linux驱动EPD Driver for linux k
评论
共有 条评论