Search
lxdream.org :: lxdream/test/testaica.c
lxdream 0.9.1
released Jun 29
Download Now
filename test/testaica.c
changeset 812:8cc61d5ea1f8
next821:4398dafeb77d
author nkeynes
date Mon Aug 18 12:20:28 2008 +0000 (15 years ago)
permissions -rw-r--r--
last change Implement memcpy_to_aica, still a work in progress though
file annotate diff log raw
nkeynes@812
     1
/**
nkeynes@812
     2
 * $Id: testdata.c 602 2008-01-15 20:50:23Z nkeynes $
nkeynes@812
     3
 * 
nkeynes@812
     4
 * AICA test loader
nkeynes@812
     5
 *
nkeynes@812
     6
 * Copyright (c) 2006 Nathan Keynes.
nkeynes@812
     7
 *
nkeynes@812
     8
 * This program is free software; you can redistribute it and/or modify
nkeynes@812
     9
 * it under the terms of the GNU General Public License as published by
nkeynes@812
    10
 * the Free Software Foundation; either version 2 of the License, or
nkeynes@812
    11
 * (at your option) any later version.
nkeynes@812
    12
 *
nkeynes@812
    13
 * This program is distributed in the hope that it will be useful,
nkeynes@812
    14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
nkeynes@812
    15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
nkeynes@812
    16
 * GNU General Public License for more details.
nkeynes@812
    17
 */
nkeynes@812
    18
nkeynes@812
    19
#include <stdio.h>
nkeynes@812
    20
nkeynes@812
    21
#include "lib.h"
nkeynes@812
    22
nkeynes@812
    23
#define AICA_RAM_BASE 0x00800000
nkeynes@812
    24
nkeynes@812
    25
#define AICA_SYSCALL (AICA_RAM_BASE+0x30)
nkeynes@812
    26
#define AICA_SYSCALL_ARG1 (AICA_SYSCALL+4)
nkeynes@812
    27
#define AICA_SYSCALL_ARG2 (AICA_SYSCALL+8)
nkeynes@812
    28
#define AICA_SYSCALL_ARG3 (AICA_SYSCALL+12)
nkeynes@812
    29
#define AICA_SYSCALL_RETURN (AICA_SYSCALL+4)
nkeynes@812
    30
nkeynes@812
    31
#define SYS_READ 0
nkeynes@812
    32
#define SYS_WRITE 1
nkeynes@812
    33
#define SYS_OPEN 2
nkeynes@812
    34
#define SYS_CLOSE 3
nkeynes@812
    35
#define SYS_CREAT 4
nkeynes@812
    36
#define SYS_LINK 5
nkeynes@812
    37
#define SYS_UNLINK 6
nkeynes@812
    38
#define SYS_CHDIR 7
nkeynes@812
    39
#define SYS_CHMOD 8
nkeynes@812
    40
#define SYS_LSEEK 9
nkeynes@812
    41
#define SYS_FSTAT 10
nkeynes@812
    42
#define SYS_TIME 11
nkeynes@812
    43
#define SYS_STAT 12
nkeynes@812
    44
#define SYS_UTIME 13
nkeynes@812
    45
#define SYS_ASSIGNWRKMEM 14
nkeynes@812
    46
#define SYS_EXIT 15
nkeynes@812
    47
#define SYS_OPENDIR 16
nkeynes@812
    48
#define SYS_CLOSEDIR 17
nkeynes@812
    49
#define SYS_READDIR 18
nkeynes@812
    50
#define SYS_GETHOSTINFO 19
nkeynes@812
    51
nkeynes@812
    52
uint32_t do_syscall( uint32_t syscall, uint32_t arg1, uint32_t arg2, uint32_t arg3 )
nkeynes@812
    53
{
nkeynes@812
    54
    uint32_t fd, len;
nkeynes@812
    55
    char *data;
nkeynes@812
    56
    
nkeynes@812
    57
    switch( syscall ) {
nkeynes@812
    58
    case SYS_READ:
nkeynes@812
    59
        fd = arg1;
nkeynes@812
    60
        data = (char *)(AICA_RAM_BASE + (arg2 & 0x001FFFFF));
nkeynes@812
    61
        len = arg3;
nkeynes@812
    62
        return read( fd, data, len );
nkeynes@812
    63
    case SYS_WRITE:
nkeynes@812
    64
        fd = arg1;
nkeynes@812
    65
        data = (char *)(AICA_RAM_BASE + (arg2 & 0x001FFFFF));
nkeynes@812
    66
        len = arg3;
nkeynes@812
    67
        return write( fd, data, len );
nkeynes@812
    68
        break;
nkeynes@812
    69
    case SYS_EXIT:
nkeynes@812
    70
        aica_disable();
nkeynes@812
    71
        exit(arg1);
nkeynes@812
    72
    default:
nkeynes@812
    73
        return 0;
nkeynes@812
    74
    }        
nkeynes@812
    75
}
nkeynes@812
    76
    
nkeynes@812
    77
nkeynes@812
    78
int main( int argc, char *argv[] ) 
nkeynes@812
    79
{
nkeynes@812
    80
    char buf[65536] __attribute__((aligned(32)));
nkeynes@812
    81
    uint32_t aica_addr = AICA_RAM_BASE;
nkeynes@812
    82
    int len;
nkeynes@812
    83
    
nkeynes@812
    84
    aica_disable();
nkeynes@812
    85
    /* Load ARM program from stdin and copy to ARM memory */
nkeynes@812
    86
    while( (len = read(0, buf, sizeof(buf))) > 0 ) {
nkeynes@812
    87
        aica_dma_write( aica_addr, buf, len );
nkeynes@812
    88
        aica_addr += len;
nkeynes@812
    89
    }
nkeynes@812
    90
    
nkeynes@812
    91
    /* Main loop waiting for IO commands */
nkeynes@812
    92
    aica_enable();
nkeynes@812
    93
    do {
nkeynes@812
    94
        int syscall = long_read(AICA_SYSCALL);
nkeynes@812
    95
        if( syscall != -1 ) {
nkeynes@812
    96
            uint32_t result = do_syscall( syscall, long_read(AICA_SYSCALL_ARG1), 
nkeynes@812
    97
                    long_read(AICA_SYSCALL_ARG2), long_read(AICA_SYSCALL_ARG3) );
nkeynes@812
    98
            long_write( AICA_SYSCALL_RETURN, result );
nkeynes@812
    99
            long_write( AICA_SYSCALL, -1 );
nkeynes@812
   100
        }
nkeynes@812
   101
    } while( 1 );
nkeynes@812
   102
}
.