cregit-Linux how code gets into the kernel

Release 4.14 arch/powerpc/boot/opal.c

/*
 * Copyright (c) 2016 IBM Corporation.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; either version
 * 2 of the License, or (at your option) any later version.
 */

#include "ops.h"
#include "stdio.h"
#include "io.h"
#include <libfdt.h>
#include "../include/asm/opal-api.h"

#ifdef CONFIG_PPC64_BOOT_WRAPPER

/* Global OPAL struct used by opal-call.S */

struct opal {
	
u64 base;
	
u64 entry;

} opal;


static u32 opal_con_id;

/* see opal-wrappers.S */
int64_t opal_console_write(int64_t term_number, u64 *length, const u8 *buffer);
int64_t opal_console_read(int64_t term_number, uint64_t *length, u8 *buffer);
int64_t opal_console_write_buffer_space(uint64_t term_number, uint64_t *length);
int64_t opal_console_flush(uint64_t term_number);
int64_t opal_poll_events(uint64_t *outstanding_event_mask);

void opal_kentry(unsigned long fdt_addr, void *vmlinux_addr);


static int opal_con_open(void) { /* * When OPAL loads the boot kernel it stashes the OPAL base and entry * address in r8 and r9 so the kernel can use the OPAL console * before unflattening the devicetree. While executing the wrapper will * probably trash r8 and r9 so this kentry hook restores them before * entering the decompressed kernel. */ platform_ops.kentry = opal_kentry; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Oliver O'Halloran18100.00%2100.00%
Total18100.00%2100.00%


static void opal_con_putc(unsigned char c) { int64_t rc; uint64_t olen, len; do { rc = opal_console_write_buffer_space(opal_con_id, &olen); len = be64_to_cpu(olen); if (rc) return; opal_poll_events(NULL); } while (len < 1); olen = cpu_to_be64(1); opal_console_write(opal_con_id, &olen, &c); }

Contributors

PersonTokensPropCommitsCommitProp
Oliver O'Halloran73100.00%1100.00%
Total73100.00%1100.00%


static void opal_con_close(void) { opal_console_flush(opal_con_id); }

Contributors

PersonTokensPropCommitsCommitProp
Oliver O'Halloran13100.00%1100.00%
Total13100.00%1100.00%


static void opal_init(void) { void *opal_node; opal_node = finddevice("/ibm,opal"); if (!opal_node) return; if (getprop(opal_node, "opal-base-address", &opal.base, sizeof(u64)) < 0) return; opal.base = be64_to_cpu(opal.base); if (getprop(opal_node, "opal-entry-address", &opal.entry, sizeof(u64)) < 0) return; opal.entry = be64_to_cpu(opal.entry); }

Contributors

PersonTokensPropCommitsCommitProp
Oliver O'Halloran91100.00%1100.00%
Total91100.00%1100.00%


int opal_console_init(void *devp, struct serial_console_data *scdp) { opal_init(); if (devp) { int n = getprop(devp, "reg", &opal_con_id, sizeof(u32)); if (n != sizeof(u32)) return -1; opal_con_id = be32_to_cpu(opal_con_id); } else opal_con_id = 0; scdp->open = opal_con_open; scdp->putc = opal_con_putc; scdp->close = opal_con_close; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Oliver O'Halloran87100.00%1100.00%
Total87100.00%1100.00%

#else
int opal_console_init(void *devp, struct serial_console_data *scdp) { return -1; }

Contributors

PersonTokensPropCommitsCommitProp
Oliver O'Halloran18100.00%1100.00%
Total18100.00%1100.00%

#endif /* __powerpc64__ */

Overall Contributors

PersonTokensPropCommitsCommitProp
Oliver O'Halloran41099.76%266.67%
Ben Hutchings10.24%133.33%
Total411100.00%3100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.