OpenCores
URL https://opencores.org/ocsvn/pcie_ds_dma/pcie_ds_dma/trunk

Subversion Repositories pcie_ds_dma

[/] [pcie_ds_dma/] [trunk/] [soft/] [linux/] [common/] [utils/] [tf_workparam.cpp] - Diff between revs 2 and 6

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 2 Rev 6
Line 1... Line 1...
 
#include <stdio.h>
#include <stdlib.h>
#include <stdlib.h>
#include <string.h>
#include <string.h>
#include <stdio.h>
 
#include <stdarg.h>
#include <stdarg.h>
 
 
#include "utypes.h"
#include "utypes.h"
//#include "useful.h"
 
#include "tf_workparam.h"
#include "tf_workparam.h"
 
 
#ifdef _DEBUG
#ifdef _DEBUG
#define new DEBUG_NEW
#define new DEBUG_NEW
#undef THIS_FILE
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
static char THIS_FILE[] = __FILE__;
#endif
#endif
 
 
 
 
//
//
 
 
 
 
TF_WorkParam::TF_WorkParam(void)
TF_WorkParam::TF_WorkParam(void)
{
{
 
 
    max_item=0;
    max_item=0;
    memset( this, 0, sizeof( TF_WorkParam ) );
    memset( this, 0, sizeof( TF_WorkParam ) );
 
 
    SetDefault();
    SetDefault();
 
 
 
 
}
}
 
 
TF_WorkParam::~TF_WorkParam(void)
TF_WorkParam::~TF_WorkParam(void)
{
{
    U32 ii=0;
    U32 ii=0;
Line 66... Line 61...
                free( ps );
                free( ps );
        }
        }
    }
    }
 
 
 
 
    //ZeroMemory( this, sizeof( TF_WorkParam ) );
 
 
 
 
 
 
 
 
 
 
 
    ii=0;
    ii=0;
    /*
 
array_cfg[ii++]=STR_CFG(  0, "RGG_SideObservation", "1", (U32*)&st.Nav_LR_Side, "борт наблюдения (правый +1, левый -1)" );
 
array_cfg[ii++]=STR_CFG(  1, "lambda",          "0.0032",       (U32*)&st.lambda, "длина волны (м)" );
 
array_cfg[ii++]=STR_CFG(  2, "RliFileName",                             "..\\gol\\bmp\\_A_4Kx16k.bmp",          (U32*)&pRliFileName, "имя файла с изображением для режима иммитации РЛИ " );
 
array_cfg[ii++]=STR_CFG(  3, "SYNTH_OBZOR_cutDoppler",  "1",    (U32*)(&st.cutDoppler), "cutDoppler" );
 
*/
 
 
 
    max_item=ii;
    max_item=ii;
 
 
 
 
    /*
 
 
 
   {
 
           if( pPathVega==NULL )
 
           {
 
                 pPathVega = (char*)malloc( 1024 );
 
           }
 
 
 
                int ret=GetEnvironmentVariableA(
 
                        "VEGA",
 
                        pPathVega,
 
                        1020
 
                        );
 
                char buf[1024];
 
                if( ret==0 )
 
                        sprintf( pPathVega, "c:\\vega" );
 
 
 
                sprintf( buf, "%s\\temp\\obzor\\", pPathVega );
 
 
 
 
 
        strcpy( st.output_dir, buf );                        // директория файлов вычислений(server)
 
        strcpy( st.output_dir_loc, buf );                    // директория файлов вычислений(client)
 
 
 
        strcpy( sk.output_dir, buf );                        // директория файлов вычислений(server)
 
        strcpy( sk.output_dir_loc, buf );                    // директория файлов вычислений(client)
 
 
 
        //free( pPathVega );
 
   };
 
*/
 
    {
    {
        char str[1024];
        char str[1024];
        for( unsigned ii=0; ii<max_item; ii++ )
        for( U32 ii=0; ii<max_item; ii++ )
        {
        {
            sprintf( str, "%s  %s", array_cfg[ii].name, array_cfg[ii].def );
            sprintf( str, "%s  %s", array_cfg[ii].name, array_cfg[ii].def );
            GetParamFromStr( str );
            GetParamFromStr( str );
        }
        }
 
 
Line 135... Line 88...
 
 
    FILE *in;
    FILE *in;
 
 
    in=BRDC_fopen( fname, _BRDC("rt") );
    in=BRDC_fopen( fname, _BRDC("rt") );
    if( in==NULL ) {
    if( in==NULL ) {
        //log_out( "Не могу открыть файл конфигурации %s\r\n", fname );
        BRDC_printf( _BRDC("Can't open configuration file: %s\r\n"), fname );
        BRDC_fprintf( stderr, _BRDC("Can't open configuration file: %s\r\n"), fname );
 
        return;
        return;
    }
    }
    //log_out( "\r\nЧтение параметров из файла %s\r\n\r\n", fname );
    BRDC_printf( _BRDC("\r\nRead parameters from file: %s\r\n\r\n"), fname );
    BRDC_fprintf( stderr, _BRDC("\r\nReading parameters from file: %s\r\n\r\n"), fname );
 
 
 
    char str[512];
    char str[512];
 
 
    for( ; ; ) {
    for( ; ; ) {
        if( fgets( str, 510, in )==NULL ) {
        if( fgets( str, 510, in )==NULL ) {
Line 153... Line 104...
        str[510]=0;
        str[510]=0;
        GetParamFromStr( str );
        GetParamFromStr( str );
    }
    }
    log_out( "\r\n" );
    log_out( "\r\n" );
    fclose( in );
    fclose( in );
 
 
}
}
 
 
//! Получение параметра из строки
//! Получение параметра из строки
U32 TF_WorkParam::GetParamFromStr( char* str )
U32 TF_WorkParam::GetParamFromStr( char* str )
{
{
Line 169... Line 119...
    if( ret==2 ) {
    if( ret==2 ) {
        for( ii=0; ii<max_item; ii++ ) {
        for( ii=0; ii<max_item; ii++ ) {
            if( strcmp( array_cfg[ii].name, name )==0 ) {
            if( strcmp( array_cfg[ii].name, name )==0 ) {
                if( array_cfg[ii].is_float==0 ) {
                if( array_cfg[ii].is_float==0 ) {
                    sscanf( val, "%i", array_cfg[ii].ptr );
                    sscanf( val, "%i", array_cfg[ii].ptr );
                    // scr.log_out( "%-20s  %d\r\n", array_cfg[ii].name, *(array_cfg[ii].ptr) );
 
                } else if( array_cfg[ii].is_float==1 ) {
                } else if( array_cfg[ii].is_float==1 ) {
                    sscanf( val, "%g", (float*)array_cfg[ii].ptr );
                    sscanf( val, "%g", (float*)array_cfg[ii].ptr );
                    // scr.log_out( "%-20s  %g\r\n", array_cfg[ii].name, *((float*)(array_cfg[ii].ptr)) );
 
                } else if( array_cfg[ii].is_float==2 ) {
                } else if( array_cfg[ii].is_float==2 ) {
                    //*((CString*)array_cfg[ii].ptr)=val;
 
                    {
                    {
 
 
                        STR_CFG *cfg=array_cfg+ii;
                        STR_CFG *cfg=array_cfg+ii;
                        char **ptr=(char**)cfg->ptr;
                        char **ptr=(char**)cfg->ptr;
 
 
                        char *ps=*ptr;
                        char *ps=*ptr;
                        if( ps!=NULL )
                        if( ps!=NULL )
                            free( ps );
                            free( ps );
                        ps = (char*)malloc( 128 );
                        ps = (char*)malloc( 128 );
                        *(cfg->ptr)=((size_t)ps);
                        *(cfg->ptr)=(U32)ps;
                        sprintf( ps, "%s", val );
                        sprintf( ps, "%s", val );
                        //scr.log_out("%-20s  %s\r\n", array_cfg[ii].name, ps );
 
 
 
                    }
                    }
                } else if( array_cfg[ii].is_float==3 ) {
                } else if( array_cfg[ii].is_float==3 ) {
                    U32 v;
                    U32 v;
                    bool *p=(bool*)(array_cfg[ii].ptr);
                    bool *p=(bool*)(array_cfg[ii].ptr);
                    sscanf( val, "%d", &v );
                    sscanf( val, "%d", &v );
                    if( v ) {
                    if( v ) {
                        *p=true;
                        *p=true;
                        //scr.log_out( "%-20s  true\r\n", array_cfg[ii].name );
 
                    } else {
                    } else {
                        *p=false;
                        *p=false;
                        //scr.log_out( "%-20s  false\r\n", array_cfg[ii].name );
 
                    }
                    }
                }
                }
                break;
                break;
            }
            }
        }
        }
Line 222... Line 167...
U32 TF_WorkParam::PutParamToMemory( char* ptr, U32 max_size )
U32 TF_WorkParam::PutParamToMemory( char* ptr, U32 max_size )
{
{
    char str[256];
    char str[256];
    int len;
    int len;
    int total=0;
    int total=0;
    unsigned ii;
    U32 ii;
    STR_CFG *cfg;
    STR_CFG *cfg;
 
 
    *((U32*)ptr)=max_item;
    *((U32*)ptr)=max_item;
    total=4;
    total=4;
 
 
Line 256... Line 201...
            }
            }
            break;
            break;
 
 
        }
        }
        len=strlen( str )+1;
        len=strlen( str )+1;
        if( (total+len)<(int)max_size )
        if( (total+len)<(S32)max_size )
        {
        {
            strcpy( ptr+total, str );
            strcpy( ptr+total, str );
            total+=len;
            total+=len;
        }
        }
    }
    }
Line 272... Line 217...
{
{
    char *src=ptr;
    char *src=ptr;
    U32 len;
    U32 len;
    U32 n;
    U32 n;
    n=*((U32*)ptr);
    n=*((U32*)ptr);
    unsigned ii;
    U32 ii;
    int total=4;
    int total=4;
 
 
    for( ii=0; ii<n; ii++ )
    for( ii=0; ii<n; ii++ )
    {
    {
        src=ptr+total;
        src=ptr+total;
Line 290... Line 235...
//! Отображение параметров
//! Отображение параметров
void TF_WorkParam::ShowParam( void )
void TF_WorkParam::ShowParam( void )
{
{
        U32 ii;
        U32 ii;
        STR_CFG  *item;
        STR_CFG  *item;
        log_out( "\r\n\r\n\r\nParameters value:\r\n\r\n" );
    log_out( "\r\n\r\n\r\nParameters:\r\n\r\n" );
        for( ii=0; ii<max_item; ii++ )
        for( ii=0; ii<max_item; ii++ )
        {
        {
                item=array_cfg+ii;
                item=array_cfg+ii;
        if( item->is_float==2 )
        if( item->is_float==2 )
                {
                {
Line 330... Line 275...
                va_list marker;
                va_list marker;
                va_start( marker, format );
                va_start( marker, format );
                vsprintf( buffer, format, marker );
                vsprintf( buffer, format, marker );
                va_end( marker );
                va_end( marker );
 
 
                BRDC_fprintf( stderr, "%s", buffer );
    printf( "%s", buffer );
 
 
}
}
 
 
 No newline at end of file
 No newline at end of file

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.