Subversion Repositories SvarDOS

Rev

Rev 488 | Rev 496 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 488 Rev 492
1
/* This file is part of the SvarCOM project and is published under the terms
1
/* This file is part of the SvarCOM project and is published under the terms
2
 * of the MIT license.
2
 * of the MIT license.
3
 *
3
 *
4
 * Copyright (C) 2021 Mateusz Viste
4
 * Copyright (C) 2021 Mateusz Viste
5
 *
5
 *
6
 * Permission is hereby granted, free of charge, to any person obtaining a
6
 * Permission is hereby granted, free of charge, to any person obtaining a
7
 * copy of this software and associated documentation files (the "Software"),
7
 * copy of this software and associated documentation files (the "Software"),
8
 * to deal in the Software without restriction, including without limitation
8
 * to deal in the Software without restriction, including without limitation
9
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10
 * and/or sell copies of the Software, and to permit persons to whom the
10
 * and/or sell copies of the Software, and to permit persons to whom the
11
 * Software is furnished to do so, subject to the following conditions:
11
 * Software is furnished to do so, subject to the following conditions:
12
 *
12
 *
13
 * The above copyright notice and this permission notice shall be included in
13
 * The above copyright notice and this permission notice shall be included in
14
 * all copies or substantial portions of the Software.
14
 * all copies or substantial portions of the Software.
15
 *
15
 *
16
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22
 * DEALINGS IN THE SOFTWARE.
22
 * DEALINGS IN THE SOFTWARE.
23
 */
23
 */
24
 
24
 
25
/*
25
/*
26
 * ver
26
 * ver
27
 */
27
 */
28
 
28
 
29
#define PVER "2021.0"
29
#define PVER "2021.0"
30
#define COPYRDATE "2021"
30
#define COPYRDATE "2021"
31
 
31
 
32
static int cmd_ver(struct cmd_funcparam *p) {
32
static int cmd_ver(struct cmd_funcparam *p) {
33
  char *buff = p->BUFFER;
33
  char *buff = p->BUFFER;
34
  unsigned char maj = 0, min = 0;
34
  unsigned char maj = 0, min = 0;
35
 
35
 
36
  /* help screen */
36
  /* help screen */
37
  if (cmd_ishlp(p)) {
37
  if (cmd_ishlp(p)) {
38
    outputnl("Displays the DOS version.");
38
    outputnl("Displays the DOS version.");
39
    outputnl("");
39
    outputnl("");
40
    outputnl("ver [/about]");
40
    outputnl("ver [/about]");
41
    return(-1);
41
    return(-1);
42
  }
42
  }
43
 
43
 
44
#if 1
44
#if 1
45
  if ((p->argc == 1) && (imatch(p->argv[0], "/dbg"))) {
45
  if ((p->argc == 1) && (imatch(p->argv[0], "/dbg"))) {
46
    unsigned short far *rmod_envseg = MK_FP(p->rmod->rmodseg, RMOD_OFFSET_ENVSEG);
46
    unsigned short far *rmod_envseg = MK_FP(p->rmod->rmodseg, RMOD_OFFSET_ENVSEG);
47
    unsigned char far *rmod_exitcode = MK_FP(p->rmod->rmodseg, RMOD_OFFSET_LEXITCODE);
47
    unsigned char far *rmod_exitcode = MK_FP(p->rmod->rmodseg, RMOD_OFFSET_LEXITCODE);
48
    unsigned short far *rmod_comspecptr = MK_FP(p->rmod->rmodseg, RMOD_OFFSET_COMSPECPTR);
48
    unsigned short far *rmod_comspecptr = MK_FP(p->rmod->rmodseg, RMOD_OFFSET_COMSPECPTR);
49
    char far *fptr;
49
    char far *fptr;
50
    unsigned short i;
50
    unsigned short i;
51
    printf("rmod->rmodseg = 0x%04X\r\n", p->rmod->rmodseg);
51
    printf("rmod->rmodseg = 0x%04X\r\n", p->rmod->rmodseg);
52
    printf("rmod->origparent = %04X:%04X\r\n", p->rmod->origparent >> 16, p->rmod->origparent & 0xffff);
52
    printf("rmod->origparent = %04X:%04X\r\n", p->rmod->origparent >> 16, p->rmod->origparent & 0xffff);
53
    printf("rmod->origenvseg = 0x%04X\r\n", p->rmod->origenvseg);
53
    printf("rmod->origenvseg = 0x%04X\r\n", p->rmod->origenvseg);
54
    printf("rmod->flags = 0x%02X\r\n", p->rmod->flags);
54
    printf("rmod->flags = 0x%02X\r\n", p->rmod->flags);
55
    printf("[rmod:RMOD_OFFSET_ENVSEG] = 0x%04X\r\n", *rmod_envseg);
55
    printf("[rmod:RMOD_OFFSET_ENVSEG] = 0x%04X\r\n", *rmod_envseg);
56
    printf("environment allocated size: %u bytes\r\n", env_allocsz(*rmod_envseg));
56
    printf("environment allocated size: %u bytes\r\n", env_allocsz(*rmod_envseg));
57
    for (fptr = MK_FP(p->rmod->rmodseg, RMOD_OFFSET_BOOTDRIVE), i = 0; *fptr != 0; fptr++) buff[i++] = *fptr;
57
    for (fptr = MK_FP(p->rmod->rmodseg, RMOD_OFFSET_BOOTDRIVE), i = 0; *fptr != 0; fptr++) buff[i++] = *fptr;
58
    buff[i] = 0;
58
    buff[i] = 0;
59
    printf("[rmod:RMOD_OFFSET_BOOTCOMSPEC] = '%s'\r\n", buff);
59
    printf("[rmod:RMOD_OFFSET_BOOTCOMSPEC] = '%s'\r\n", buff);
60
    if (*rmod_comspecptr == 0) {
60
    if (*rmod_comspecptr == 0) {
61
      sprintf(buff, "NULL");
61
      sprintf(buff, "NULL");
62
    } else {
62
    } else {
63
      for (fptr = MK_FP(*rmod_envseg, *rmod_comspecptr), i = 0; *fptr != 0; fptr++) buff[i++] = *fptr;
63
      for (fptr = MK_FP(*rmod_envseg, *rmod_comspecptr), i = 0; *fptr != 0; fptr++) buff[i++] = *fptr;
64
      buff[i] = 0;
64
      buff[i] = 0;
65
    }
65
    }
66
    printf("[rmod:RMOD_OFFSET_COMSPECPTR] = '%s'\r\n", buff);
66
    printf("[rmod:RMOD_OFFSET_COMSPECPTR] = '%s'\r\n", buff);
67
    printf("[rmod:RMOD_OFFSET_LEXITCODE] = %u\r\n", *rmod_exitcode);
67
    printf("[rmod:RMOD_OFFSET_LEXITCODE] = %u\r\n", *rmod_exitcode);
68
    printf("rmod dump (first 64 bytes at [rmodseg:0100h]):\r\n");
68
    printf("rmod dump (first 64 bytes at [rmodseg:0100h]):\r\n");
69
    fptr = MK_FP(p->rmod->rmodseg, 0x100);
69
    fptr = MK_FP(p->rmod->rmodseg, 0x100);
70
    for (i = 0; i < 64; i += 16) {
70
    for (i = 0; i < 64; i += 16) {
71
      int ii;
71
      int ii;
72
      for (ii = i; ii < i + 16; ii++) printf(" %02X", fptr[ii]);
72
      for (ii = i; ii < i + 16; ii++) printf(" %02X", fptr[ii]);
73
      printf("   ");
73
      printf("   ");
74
      for (ii = i; ii < i + 16; ii++) {
74
      for (ii = i; ii < i + 16; ii++) {
75
        if (fptr[ii] < ' ') {
75
        if (fptr[ii] < ' ') {
76
          printf(".");
76
          printf(".");
77
        } else {
77
        } else {
78
          printf("%c", fptr[ii]);
78
          printf("%c", fptr[ii]);
79
        }
79
        }
80
      }
80
      }
81
      printf("\r\n");
81
      printf("\r\n");
82
    }
82
    }
83
 
83
 
84
    return(-1);
84
    return(-1);
85
  }
85
  }
86
#endif
86
#endif
87
 
87
 
88
  if ((p->argc == 1) && (imatch(p->argv[0], "/about"))) {
88
  if ((p->argc == 1) && (imatch(p->argv[0], "/about"))) {
89
    outputnl("SvarCOM is a shell interpreter for DOS kernels compatible with MS-DOS 5+.");
89
    outputnl("SvarCOM is a shell interpreter for DOS kernels compatible with MS-DOS 5+.");
90
    outputnl("");
90
    outputnl("");
91
    outputnl("This software is distributed under the terms of the MIT license.");
91
    outputnl("This software is distributed under the terms of the MIT license.");
92
    outputnl("Copyright (C) " COPYRDATE " Mateusz Viste");
92
    outputnl("Copyright (C) " COPYRDATE " Mateusz Viste");
93
    outputnl("");
93
    outputnl("");
94
    outputnl("Prace te dedykuje Milenie i Mojmirowi. Zycze wam, abyscie w swoim zyciu");
94
    outputnl("Program ten dedykuje Milenie i Mojmirowi. Zycze wam, byscie w swoim zyciu");
95
    outputnl("potrafili docenic wartosc czasow minionych, jednoczesnie czerpiac radosc z");
95
    outputnl("potrafili docenic wartosci czasu minionego, jednoczesnie czerpiac radosc");
96
    outputnl("prostych przyjemnosci dnia codziennego.  Lair, jesien 2021.");
96
    outputnl("z prostych przyjemnosci dnia codziennego.  Lair, jesien 2021.");
97
    return(-1);
97
    return(-1);
98
  }
98
  }
99
 
99
 
100
  if (p->argc != 0) {
100
  if (p->argc != 0) {
101
    outputnl("Invalid parameter");
101
    outputnl("Invalid parameter");
102
    return(-1);
102
    return(-1);
103
  }
103
  }
104
 
104
 
105
  _asm {
105
  _asm {
106
    push ax
106
    push ax
107
    push bx
107
    push bx
108
    push cx
108
    push cx
109
    mov ah, 0x30   /* Get DOS version number */
109
    mov ah, 0x30   /* Get DOS version number */
110
    int 0x21       /* AL=maj_ver_num  AH=min_ver_num  BX,CX=OEM */
110
    int 0x21       /* AL=maj_ver_num  AH=min_ver_num  BX,CX=OEM */
111
    mov [maj], al
111
    mov [maj], al
112
    mov [min], ah
112
    mov [min], ah
113
    pop cx
113
    pop cx
114
    pop bx
114
    pop bx
115
    pop ax
115
    pop ax
116
  }
116
  }
117
 
117
 
118
  sprintf(buff, "DOS kernel version %u.%u", maj, min);
118
  sprintf(buff, "DOS kernel version %u.%u", maj, min);
119
 
119
 
120
  outputnl(buff);
120
  outputnl(buff);
121
  outputnl("SvarCOM shell ver " PVER);
121
  outputnl("SvarCOM shell ver " PVER);
122
  return(-1);
122
  return(-1);
123
}
123
}
124
 
124