Changeset 5f0c664 in mainline


Ignore:
Timestamp:
2006-05-12T12:55:10Z (19 years ago)
Author:
Jakub Jermar <jakub@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
18093eaf
Parents:
8d4f2ae
Message:

Change coding style in vesa.c and do some minor changes.

Files:
3 edited

Legend:

Unmodified
Added
Removed
  • arch/ia32/include/vesa.h

    r8d4f2ae r5f0c664  
    11/*
    2  * Copyright (C) 2006-2006 Jakub Vana
     2 * Copyright (C) 2006 Jakub Vana
    33 * All rights reserved.
    44 *
     
    3030#define __VESA_H__
    3131
    32 
    33 int vesa_present(void);
    34 void vesa_init(void);
    35 
     32extern int vesa_present(void);
     33extern void vesa_init(void);
    3634
    3735#endif
  • arch/ia32/src/drivers/vesa.c

    r8d4f2ae r5f0c664  
    11/*
    2  * Copyright (C) 2006-2006 Jakub Vana
     2 * Copyright (C) 2006 Jakub Vana
    33 * All rights reserved.
    44 *
     
    3737#include <arch/mm/page.h>
    3838#include <synch/spinlock.h>
     39#include <arch/asm.h>
    3940#include <arch/types.h>
    40 #include <arch/asm.h>
     41#include <typedefs.h>
    4142#include <memstr.h>
     43#include <bitops.h>
    4244
    4345__u32 vesa_ph_addr;
     
    4749__u16 vesa_scanline;
    4850
    49 
    5051int vesa_present(void)
    5152{
    52         if(vesa_width!=0xffff) return true;
    53         if(vesa_height!=0xffff) return true;
     53        if (vesa_width != 0xffff)
     54                return true;
     55        if (vesa_height != 0xffff)
     56                return true;
    5457        return false;
    5558}
    5659
     60static count_t vesa_frame_order(void)
     61{
     62        __u32 x = vesa_scanline*vesa_height;
     63        if (x <= FRAME_SIZE)
     64                return 1;
    5765
    58 static __u32 log2(__u32 x)
    59 {
    60         __u32 l=2;
    61         if(x<=PAGE_SIZE) return PAGE_WIDTH+1;
    62        
    63         x--;
    64         while(x>>=1) l++;
    65         return l;
     66        return (fnzb32(x - 1) + 1) - FRAME_WIDTH;
    6667}
    6768
     
    6970{
    7071        int a;
     72        __address vram_lin_addr;
    7173
    72         __address videoram_lin_addr;
     74        vram_lin_addr = PA2KA(PFN2ADDR(frame_alloc(vesa_frame_order(), FRAME_KA)));
     75        /* Map videoram */
     76        for (a = 0; a < ((vesa_scanline * vesa_height + PAGE_SIZE - 1) >> PAGE_WIDTH); a++)
     77                page_mapping_insert(AS_KERNEL, vram_lin_addr+a*4096, vesa_ph_addr+a*4096, PAGE_NOT_CACHEABLE);
    7378
    74         videoram_lin_addr=PA2KA(PFN2ADDR(frame_alloc( log2(vesa_scanline*vesa_height) -FRAME_WIDTH,FRAME_KA)));
    75         /* Map videoram */
    76         for(a=0;a<((vesa_scanline*vesa_height+PAGE_SIZE-1)>>PAGE_WIDTH);a++)
    77         page_mapping_insert(AS_KERNEL, videoram_lin_addr+a*4096, vesa_ph_addr+a*4096, PAGE_NOT_CACHEABLE);
    78        
    79         fb_init( videoram_lin_addr,vesa_width,vesa_height,vesa_bpp,vesa_scanline);
     79        fb_init(vram_lin_addr, vesa_width, vesa_height, vesa_bpp, vesa_scanline);
    8080}
    8181
    8282#endif
    83 
  • generic/include/bitops.h

    r8d4f2ae r5f0c664  
    3333
    3434
    35 /** Return position of first non-zero bit from left.
     35/** Return position of first non-zero bit from left (i.e. [log_2(arg)]).
    3636 *
    3737 * If number is zero, it returns 0
Note: See TracChangeset for help on using the changeset viewer.