如何将控制台输出重定向到VxWorks Shell中的文件?

时间:2018-10-17 07:29:15

标签: vxworks

在Windows或Linux中,通常我们将控制台输出重定向到如下文件:

Windows:

dir > text

Linux:

ls -l > text

我想知道如何在VxWorks shell中做类似的事情。

3 个答案:

答案 0 :(得分:1)

您可以尝试以下操作:

-> saveFd = open("myfile.txt",0x102, 0777 )
-> oldFd = ioGlobalStdGet(1)
-> ioGlobalStdSet(1, saveFd)
-> runmytest()
...
-> ioGlobalStdSet(1, oldFd)

这会将所有代码重定向到您打开的文件,本例中为myfile.txt

答案 1 :(得分:0)

我将“ saveFd = open(“ myfile.txt”,0x102,0777)“中的” 0x102“更改为” 0x202“,然后它可以工作了。所有控制台显示都被重定向到“ myfile.txt”。 在上一篇文章中,我犯了一个错误。我认为它在“ ioGlobalStdSet(1,saveFd)”之后挂起。它没有挂起,但是将所有显示重定向到“ myfile.txt”,并且我使用了“ CTL-C”来停止重定向。

答案 2 :(得分:0)

以下代码段显示了如何将所有串行控制台输出保存到文件中。

尝试-> tyco0_write_to_file 4096

#include <tyLib.h>
#include <private/iosLibP.h>

int tyco0_log_max_size = -1;
int tyco0_log_fd = -1;

int tyco0_write_hook(TY_DEV_ID pTyDev, char *buffer, int nbytes)
{
    FD_ENTRY *p_fd_entry;
    static int bytes_written = 0;

    if ('0' == pTyDev->devHdr.name[6]) { /* /tyCo/0 */
        if ((bytes_written+nbytes)<tyco0_log_max_size) {
            (void)write(tyco0_log_fd,buffer,nbytes);
            bytes_written += nbytes;
        }
        else {
            (void)write(tyco0_log_fd,buffer,tyco0_log_max_size-bytes_written);
            p_fd_entry = iosFdMap(1);
            p_fd_entry->pDrvEntry->de_write = tyWrite;
            close(tyco0_log_fd);
            bytes_written = 0;
        }
    }

    return tyWrite(pTyDev,buffer,nbytes);
}

int tyco0_write_to_file(int file_max_size)
{
    FD_ENTRY *p_fd_entry;

    p_fd_entry = iosFdMap(1); /*  /tyCo/0 */
    if (NULL==p_fd_entry) {
        perror("iosFdMap");
        return -1;
    }

    tyco0_log_fd = open("/ram/tyco0.log",O_CREAT|O_RDWR,0);
    if (tyco0_log_fd == -1) {
        perror("open");
        return -1;
    }

    if (file_max_size <= 0) {
        file_max_size = 1024;
    }
    tyco0_log_max_size = file_max_size;

    if (p_fd_entry->pDrvEntry->de_write == tyWrite) {
        p_fd_entry->pDrvEntry->de_write = tyco0_write_hook;
    }
    else {
        printf("tyWrite not found\n");
        close(tyco0_log_fd);
        return -1;
     }

    return 0;
}