Ignore:
Timestamp:
2006-09-13T14:23:22Z (18 years ago)
Author:
Jakub Jermar <jakub@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
b254b3b
Parents:
34d9469e
Message:

Unfortunatelly, the sparc64's FPRS register is writable by non-privileged software
so we cannot save only half of the FPU context depending on FPRS dirty bits.
Instead, we must save the entire FPU register file.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • kernel/arch/sparc64/src/fpu_context.c

    r34d9469e rda02e69  
    4040void fpu_context_save(fpu_context_t *fctx)
    4141{
    42         fprs_reg_t fprs;
     42        __asm__ volatile (
     43                "std %%f0, %0\n"
     44                "std %%f2, %1\n"
     45                "std %%f4, %2\n"
     46                "std %%f6, %3\n"
     47                "std %%f8, %4\n"
     48                "std %%f10, %5\n"
     49                "std %%f12, %6\n"
     50                "std %%f14, %7\n"
     51                "std %%f16, %8\n"
     52                "std %%f18, %9\n"
     53                "std %%f20, %10\n"
     54                "std %%f22, %11\n"
     55                "std %%f24, %12\n"
     56                "std %%f26, %13\n"
     57                "std %%f28, %14\n"
     58                "std %%f30, %15\n"
     59                : "=m" (fctx->d[0]), "=m" (fctx->d[1]), "=m" (fctx->d[2]), "=m" (fctx->d[3]),
     60                  "=m" (fctx->d[4]), "=m" (fctx->d[5]), "=m" (fctx->d[6]), "=m" (fctx->d[7]),
     61                  "=m" (fctx->d[8]), "=m" (fctx->d[9]), "=m" (fctx->d[10]), "=m" (fctx->d[11]),
     62                  "=m" (fctx->d[12]), "=m" (fctx->d[13]), "=m" (fctx->d[14]), "=m" (fctx->d[15])
     63        );
     64
     65        /*
     66         * We need to split loading of the floating-point registers because
     67         * GCC (4.1.1) can't handle more than 30 operands in one asm statement.
     68         */
    4369       
    44         fprs.value = fprs_read();
    45 
    46         if (fprs.dl) {
    47                 /*
    48                  * The lower half of floating-point registers is dirty.
    49                  * Spill it to memory.
    50                  */
    51                 __asm__ volatile (
    52                         "std %%f0, %0\n"
    53                         "std %%f2, %1\n"
    54                         "std %%f4, %2\n"
    55                         "std %%f6, %3\n"
    56                         "std %%f8, %4\n"
    57                         "std %%f10, %5\n"
    58                         "std %%f12, %6\n"
    59                         "std %%f14, %7\n"
    60                         "std %%f16, %8\n"
    61                         "std %%f18, %9\n"
    62                         "std %%f20, %10\n"
    63                         "std %%f22, %11\n"
    64                         "std %%f24, %12\n"
    65                         "std %%f26, %13\n"
    66                         "std %%f28, %14\n"
    67                         "std %%f30, %15\n"
    68                         : "=m" (fctx->d[0]), "=m" (fctx->d[1]), "=m" (fctx->d[2]), "=m" (fctx->d[3]),
    69                           "=m" (fctx->d[4]), "=m" (fctx->d[5]), "=m" (fctx->d[6]), "=m" (fctx->d[7]),
    70                           "=m" (fctx->d[8]), "=m" (fctx->d[9]), "=m" (fctx->d[10]), "=m" (fctx->d[11]),
    71                           "=m" (fctx->d[12]), "=m" (fctx->d[13]), "=m" (fctx->d[14]), "=m" (fctx->d[15])
    72                 );
    73                 fprs.dl = false;
    74         }
    75        
    76         if (fprs.du) { 
    77                 /*
    78                  * The upper half of floating-point registers is dirty.
    79                  * Spill it to memory.
    80                  */
    81                 __asm__ volatile (
    82                         "std %%f32, %0\n"
    83                         "std %%f34, %1\n"
    84                         "std %%f36, %2\n"
    85                         "std %%f38, %3\n"
    86                         "std %%f40, %4\n"
    87                         "std %%f42, %5\n"
    88                         "std %%f44, %6\n"
    89                         "std %%f46, %7\n"
    90                         "std %%f48, %8\n"
    91                         "std %%f50, %9\n"
    92                         "std %%f52, %10\n"
    93                         "std %%f54, %11\n"
    94                         "std %%f56, %12\n"
    95                         "std %%f58, %13\n"
    96                         "std %%f60, %14\n"
    97                         "std %%f62, %15\n"
    98                         : "=m" (fctx->d[16]), "=m" (fctx->d[17]), "=m" (fctx->d[18]), "=m" (fctx->d[19]),
    99                           "=m" (fctx->d[20]), "=m" (fctx->d[21]), "=m" (fctx->d[22]), "=m" (fctx->d[23]),
    100                           "=m" (fctx->d[24]), "=m" (fctx->d[25]), "=m" (fctx->d[26]), "=m" (fctx->d[27]),
    101                           "=m" (fctx->d[28]), "=m" (fctx->d[29]), "=m" (fctx->d[30]), "=m" (fctx->d[31])
    102                 );
    103                 fprs.du = false;
    104         }
    105        
    106         fprs_write(fprs.value);
     70        __asm__ volatile (
     71                "std %%f32, %0\n"
     72                "std %%f34, %1\n"
     73                "std %%f36, %2\n"
     74                "std %%f38, %3\n"
     75                "std %%f40, %4\n"
     76                "std %%f42, %5\n"
     77                "std %%f44, %6\n"
     78                "std %%f46, %7\n"
     79                "std %%f48, %8\n"
     80                "std %%f50, %9\n"
     81                "std %%f52, %10\n"
     82                "std %%f54, %11\n"
     83                "std %%f56, %12\n"
     84                "std %%f58, %13\n"
     85                "std %%f60, %14\n"
     86                "std %%f62, %15\n"
     87                : "=m" (fctx->d[16]), "=m" (fctx->d[17]), "=m" (fctx->d[18]), "=m" (fctx->d[19]),
     88                  "=m" (fctx->d[20]), "=m" (fctx->d[21]), "=m" (fctx->d[22]), "=m" (fctx->d[23]),
     89                  "=m" (fctx->d[24]), "=m" (fctx->d[25]), "=m" (fctx->d[26]), "=m" (fctx->d[27]),
     90                  "=m" (fctx->d[28]), "=m" (fctx->d[29]), "=m" (fctx->d[30]), "=m" (fctx->d[31])
     91        );
    10792       
    10893        __asm__ volatile ("stx %%fsr, %0\n" : "=m" (fctx->fsr));
     
    11196void fpu_context_restore(fpu_context_t *fctx)
    11297{
    113         fprs_reg_t fprs;
    114        
    115         fprs.value = fprs_read();
    116        
    11798        __asm__ volatile (
    11899                "ldd %0, %%f0\n"
     
    168149        );
    169150       
    170         fprs.dl = fprs.du = false;
    171         fprs_write(fprs.value);
    172        
    173151        __asm__ volatile ("ldx %0, %%fsr\n" : : "m" (fctx->fsr));
    174152}
Note: See TracChangeset for help on using the changeset viewer.