Subversion Repositories HelenOS

Rev

Rev 1881 | Rev 1897 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  1. /*
  2.  * Copyright (C) 2005 Martin Decky
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  *
  9.  * - Redistributions of source code must retain the above copyright
  10.  *   notice, this list of conditions and the following disclaimer.
  11.  * - Redistributions in binary form must reproduce the above copyright
  12.  *   notice, this list of conditions and the following disclaimer in the
  13.  *   documentation and/or other materials provided with the distribution.
  14.  * - The name of the author may not be used to endorse or promote products
  15.  *   derived from this software without specific prior written permission.
  16.  *
  17.  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  18.  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  19.  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  20.  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  21.  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  22.  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  23.  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  24.  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  25.  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  26.  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27.  */
  28.  
  29. #include "main.h"
  30. #include <printf.h>
  31. #include "asm.h"
  32. #include "_components.h"
  33. #include <balloc.h>
  34. #include <ofw.h>
  35. #include <ofw_tree.h>
  36. #include "ofwarch.h"
  37. #include <align.h>
  38.  
  39. #define KERNEL_VIRTUAL_ADDRESS 0x400000
  40.  
  41. bootinfo_t bootinfo;
  42.  
  43. void bootstrap(void)
  44. {
  45.     printf("HelenOS SPARC64 Bootloader\n");
  46.  
  47.     component_t components[COMPONENTS];
  48.     init_components(components);
  49.  
  50.     if (!ofw_memmap(&bootinfo.memmap)) {
  51.         printf("Error: unable to get memory map, halting.\n");
  52.         halt();
  53.     }
  54.    
  55.     if (bootinfo.memmap.total == 0) {
  56.         printf("Error: no memory detected, halting.\n");
  57.         halt();
  58.     }
  59.    
  60.     if (!ofw_screen(&bootinfo.screen)) {
  61.         printf("Error: unable to get screen properties, halting.\n");
  62.         halt();
  63.     }
  64.     bootinfo.screen.addr = ofw_translate(bootinfo.screen.addr);
  65.     /* transform scanline to bytes with respect to potential alignment */
  66.     bootinfo.screen.scanline = bootinfo.screen.scanline*bpp2align[bootinfo.screen.bpp >> 3];
  67.    
  68.     if (!ofw_keyboard(&bootinfo.keyboard))
  69.         printf("Error: unable to get keyboard properties\n");
  70.  
  71.     if (!ofw_cpu(&bootinfo.cpu))
  72.         printf("Error: unable to get cpu properties\n");
  73.  
  74.     printf("\nDevice statistics\n");
  75.     printf(" cpu: %dMHz\n", bootinfo.cpu.clock_frequency/1000000);
  76.     printf(" memory: %dM\n", bootinfo.memmap.total>>20);
  77.     printf(" screen at %P, resolution %dx%d, %d bpp (scanline %d bytes)\n", (uintptr_t) bootinfo.screen.addr, bootinfo.screen.width, bootinfo.screen.height, bootinfo.screen.bpp, bootinfo.screen.scanline);
  78.     printf(" keyboard at %P (size %d bytes)\n", (uintptr_t) bootinfo.keyboard.addr, bootinfo.keyboard.size);
  79.  
  80.     printf("\nMemory statistics\n");
  81.     printf(" kernel entry point at %P\n", KERNEL_VIRTUAL_ADDRESS);
  82.     printf(" %P: boot info structure\n", &bootinfo);
  83.    
  84.     unsigned int i;
  85.     for (i = 0; i < COMPONENTS; i++)
  86.         printf(" %P: %s image (size %d bytes)\n", components[i].start, components[i].name, components[i].size);
  87.  
  88.     void * base = (void *) KERNEL_VIRTUAL_ADDRESS;
  89.     unsigned int top = 0;
  90.  
  91.     printf("\nCopying components\n");
  92.     bootinfo.taskmap.count = 0;
  93.     for (i = 0; i < COMPONENTS; i++) {
  94.         printf(" %s...", components[i].name);
  95.         top = ALIGN_UP(top, PAGE_SIZE);
  96.         memcpy(base + top, components[i].start, components[i].size);
  97.         if (i > 0) {
  98.             bootinfo.taskmap.tasks[bootinfo.taskmap.count].addr = base + top;
  99.             bootinfo.taskmap.tasks[bootinfo.taskmap.count].size = components[i].size;
  100.             bootinfo.taskmap.count++;
  101.         }
  102.         top += components[i].size;
  103.         printf("done.\n");
  104.     }
  105.  
  106.     balloc_init(&bootinfo.ballocs, ALIGN_UP(((uintptr_t) base) + top, PAGE_SIZE));
  107.  
  108.     printf("\nCanonizing OpenFirmware device tree...");
  109.     bootinfo.ofw_root = ofw_tree_build();
  110.     printf("done.\n");
  111.  
  112.     printf("\nBooting the kernel...\n");
  113.     jump_to_kernel((void *) KERNEL_VIRTUAL_ADDRESS, &bootinfo, sizeof(bootinfo));
  114. }
  115.