1 /*
2 * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
3 * Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without modification,
6 * are permitted provided that the following conditions are met:
7 *
8 * 1. Redistributions of source code must retain the above copyright notice, this list of
9 * conditions and the following disclaimer.
10 *
11 * 2. Redistributions in binary form must reproduce the above copyright notice, this list
12 * of conditions and the following disclaimer in the documentation and/or other materials
13 * provided with the distribution.
14 *
15 * 3. Neither the name of the copyright holder nor the names of its contributors may be used
16 * to endorse or promote products derived from this software without specific prior written
17 * permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
26 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
27 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
28 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
29 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
32 #ifndef _OSTEST_H
33 #define _OSTEST_H
34
35 #ifndef SWTMR_TEST
36 #define SWTMR_TEST
37 #endif
38 #include "iCunit.h"
39 #include <sched.h>
40 #include <pthread.h>
41 #include <stdio.h>
42 #include <stdlib.h>
43 #include <limits.h>
44 #include <string.h>
45 #include <unistd.h>
46 #include <sys/mman.h>
47 #include <errno.h>
48 #include <stdint.h>
49 #include <stdarg.h>
50 #include <bits/alltypes.h>
51 #include <sys/prctl.h>
52 #include <time.h>
53 #include <search.h>
54 #include <sys/mount.h>
55 #include "los_typedef.h"
56 #include "sys/wait.h"
57 #include "glob.h"
58 #include "mntent.h"
59 #include "securectype.h"
60 #include "securec.h"
61 #include <wchar.h>
62 #include <fcntl.h>
63 #include <sys/stat.h>
64 #include <dirent.h>
65 #include <semaphore.h>
66
67 #ifndef OK
68 #define OK 0
69 #endif
70
71 #define dprintf printf
72 #define ENOERR OK
73 #define LOSCFG_BASE_CORE_TSK_CONFIG 1024
74
75 #define USER_PROCESS_PRIORITY_HIGHEST 10
76 #define USER_PROCESS_PRIORITY_LOWEST 31
77 #define TEST_TASK_PARAM_INIT(stTestTask, task_name, entry, prio) \
78 do { \
79 (void)memset_s(&stTestTask, sizeof(TSK_INIT_PARAM_S), 0, sizeof(TSK_INIT_PARAM_S)); \
80 stTestTask.pfnTaskEntry = (TSK_ENTRY_FUNC)entry; \
81 stTestTask.uwStackSize = LOS_TASK_MIN_STACK_SIZE; \
82 stTestTask.pcName = task_name; \
83 stTestTask.usTaskPrio = prio; \
84 stTestTask.uwResved = LOS_TASK_STATUS_DETACHED; \
85 } while (0)
86
87 #ifdef LOSCFG_KERNEL_SMP
88 #define TEST_TASK_PARAM_INIT_AFFI(stTestTask, task_name, entry, prio, affi) \
89 TEST_TASK_PARAM_INIT(stTestTask, task_name, entry, prio) \
90 stTestTask.usCpuAffiMask = affi;
91 #else
92 #define TEST_TASK_PARAM_INIT_AFFI(stTestTask, task_name, entry, prio, affi) \
93 TEST_TASK_PARAM_INIT(stTestTask, task_name, entry, prio)
94 #endif
95 #define JFFS_BASE_MTD_ADDR 0x100000
96 #define JFFS_BASE_MTD_LEN 0x600000
97
98 #define LOS_TASK_MIN_STACK_SIZE 2048
99 #define TASK_PRIO_TEST 20
100 #ifdef LOSCFG_AARCH64
101 #define TASK_STACK_SIZE_TEST (LOS_TASK_MIN_STACK_SIZE * 3)
102 #else
103 #define TASK_STACK_SIZE_TEST LOS_TASK_MIN_STACK_SIZE
104 #endif
105 #define LOS_MS_PER_TICK (OS_SYS_MS_PER_SECOND / LOSCFG_BASE_CORE_TICK_PER_SECOND)
106
107 #define HWI_NUM_INTVALID OS_HWI_MAX_NUM
108 #define writel(value, address) WRITE_UINT32(value, address)
109
110 extern UINT32 PrepareFileEnv(CHAR *pathList[], CHAR *streamList[], INT32 streamLen[], INT32 listCnt);
111 extern UINT32 RecoveryFileEnv(CHAR *pathList[], INT32 listCnt);
112 extern UINT32 PosixPthreadInit(pthread_attr_t *attr, int pri);
113 extern UINT32 PosixPthreadDestroy(pthread_attr_t *attr, pthread_t thread);
114
115 extern VOID TaskHold(UINT64 sec);
116
117 extern UINT32 TaskCountGetTest(VOID);
118 extern UINT32 Sem_Count_Get_Test(VOID);
119 extern UINT32 QueueCountGetTest(VOID);
120 extern UINT32 Swtmr_Count_Get_Test(VOID);
121 extern void hal_interrupt_set_affinity(uint32_t irq, uint32_t cpuMask);
122
123 #define TASK_EXISTED_NUM (TaskCountGetTest())
124 #define QUEUE_EXISTED_NUM (QueueCountGetTest())
125 #define SWTMR_EXISTED_NUM (Swtmr_Count_Get_Test())
126 #define SEM_EXISTED_NUM (Sem_Count_Get_Test())
127
128 extern void TEST_TEST_HwiDelete(unsigned int irq, void *dev_id);
129 extern void TEST_HwiTrigger(unsigned int irq);
130 extern void TestExtraTaskDelay(UINT32 tick);
131 extern UINT64 TestTickCountGet(void);
132 extern UINT64 TestTickCountByCurrCpuid(void);
133 extern void TestBusyTaskDelay(UINT32 tick);
134 extern void *malloc(size_t size);
135 extern void TEST_DumpCpuid(void);
136 extern u_long T_random(void);
137 extern VOID TestAssertWaitDelay(UINT32 *testCount, UINT32 flag);
138
139 UINT32 LosTaskDelay(UINT32 tick);
140 #define TEST_HwiDelete(ID) TEST_TEST_HwiDelete(ID, NULL)
141 #define TEST_HwiClear(ID) HalIrqMask(ID)
142 #define TEST_HwiTriggerDelay LosTaskDelay(200 * LOSCFG_BASE_CORE_TICK_PER_SECOND / 1000)
143 #define TEST_HwiCreate(ID, prio, mode, Func, arg) LOS_HwiCreate(ID, prio, mode, Func, arg)
144
145 #if HUAWEI_ENV_NFS
146 #define NFS_MOUNT_DIR "/nfs"
147 #define NFS_MAIN_DIR NFS_MOUNT_DIR
148 #define NFS_PATH_NAME "/nfs/test"
149 #else
150 #define NFS_MOUNT_DIR "/nfs"
151 #define NFS_MAIN_DIR NFS_MOUNT_DIR
152 #define NFS_PATH_NAME "/nfs/test"
153 #endif
154
155 #define WIN_MOUNT_PATH "/nfs"
156 #define WIN_NFS_MOUNT_DIR WIN_MOUNT_PATH
157 #define WIN_NFS_MAIN_DIR WIN_NFS_MOUNT_DIR
158 #define WIN_NFS_PATH_NAME "/nfs/test"
159
160 #define HWI_NUM_INT0 0
161 #define HWI_NUM_INT1 1
162 #define HWI_NUM_INT2 2
163 #define HWI_NUM_INT3 3
164 #define HWI_NUM_INT4 4
165 #define HWI_NUM_INT5 5
166 #define HWI_NUM_INT6 6
167 #define HWI_NUM_INT7 7
168 #define HWI_NUM_INT11 11
169 #define HWI_NUM_INT12 12
170 #define HWI_NUM_INT13 13
171 #define HWI_NUM_INT14 14
172 #define HWI_NUM_INT15 15
173 #define HWI_NUM_INT16 16
174 #define HWI_NUM_INT17 17
175 #define HWI_NUM_INT18 18
176 #define HWI_NUM_INT19 19
177 #define HWI_NUM_INT21 21
178 #define HWI_NUM_INT22 22
179 #define HWI_NUM_INT23 23
180 #define HWI_NUM_INT24 24
181 #define HWI_NUM_INT25 25
182 #define HWI_NUM_INT26 26
183 #define HWI_NUM_INT27 27
184 #define HWI_NUM_INT28 28
185 #define HWI_NUM_INT30 30
186 #define HWI_NUM_INT31 31
187 #define HWI_NUM_INT32 32
188 #define HWI_NUM_INT33 33
189 #define HWI_NUM_INT34 34
190 #define HWI_NUM_INT35 35
191 #define HWI_NUM_INT42 42
192 #define HWI_NUM_INT45 45
193 #define HWI_NUM_INT46 46
194 #define HWI_NUM_INT50 50
195 #define HWI_NUM_INT55 55
196 #define HWI_NUM_INT56 56
197 #define HWI_NUM_INT57 57
198 #define HWI_NUM_INT58 58
199 #define HWI_NUM_INT59 59
200 #define HWI_NUM_INT60 60
201 #define HWI_NUM_INT61 61
202 #define HWI_NUM_INT63 63
203 #define HWI_NUM_INT62 62
204 #define HWI_NUM_INT68 68
205 #define HWI_NUM_INT69 69
206
207 #define HWI_NUM_INT95 95
208 #define HWI_NUM_INT114 114
209 #define HWI_NUM_INT169 169
210
211 #if defined TESTPBXA9
212 #define HWI_NUM_TEST HWI_NUM_INT56
213 #define HWI_NUM_TEST1 HWI_NUM_INT57
214 #define HWI_NUM_TEST0 HWI_NUM_INT58
215 #define HWI_NUM_TEST2 HWI_NUM_INT59
216 #define HWI_NUM_TEST3 HWI_NUM_INT60
217 #elif defined TEST3518EV300
218 #define HWI_NUM_TEST0 HWI_NUM_INT58
219 #define HWI_NUM_TEST HWI_NUM_INT59
220 #define HWI_NUM_TEST1 HWI_NUM_INT60
221 #define HWI_NUM_TEST2 HWI_NUM_INT61
222 #define HWI_NUM_TEST3 HWI_NUM_INT68
223 #elif defined TEST3516DV300
224 #define HWI_NUM_TEST HWI_NUM_INT56
225 #define HWI_NUM_TEST1 HWI_NUM_INT57
226 #define HWI_NUM_TEST0 HWI_NUM_INT58
227 #define HWI_NUM_TEST2 HWI_NUM_INT59
228 #define HWI_NUM_TEST3 HWI_NUM_INT60
229 #endif
230
231 #define TEST_TASKDELAY_1TICK 1
232 #define TEST_TASKDELAY_2TICK 2
233 #define TEST_TASKDELAY_4TICK 4
234 #define TEST_TASKDELAY_10TICK 10
235 #define TEST_TASKDELAY_20TICK 20
236 #define TEST_TASKDELAY_50TICK 50
237
238 #define uart_printf_func printf
239
240 #ifndef VFS_STAT_PRINTF
241 #define VFS_STAT_PRINTF 0
242 #endif
243
244 #ifndef VFS_STATFS_PRINTF
245 #define VFS_STATFS_PRINTF 0
246 #endif
247
248 #define OPEN_FILE_MAX 20
249
250 #define HUAWEI_ENV_NFS 0
251
252 #ifndef TEST_RESOURCELEAK_CHECK
253 #define TEST_RESOURCELEAK_CHECK YES
254 #endif
255
256 #ifndef TEST_MODULE_CHECK
257 #define TEST_MODULE_CHECK YES
258 #endif
259
260 extern UINT32 g_shellTestQueueID;
261 extern UINT32 g_testCount;
262 extern UINT32 g_testCount1;
263 extern UINT32 g_testCount2;
264 extern UINT32 g_testCount3;
265 extern UINT32 g_flowcheck;
266 extern UINT32 g_failResult;
267 extern UINT32 g_passResult;
268 extern UINT32 g_testTskHandle;
269 extern UINT32 g_testTaskID01;
270 extern UINT32 g_testTaskID02;
271 extern UINT32 g_testTaskID03;
272 extern UINT32 g_testTaskID04;
273 extern UINT32 g_hwiNum1;
274 extern UINT32 g_hwiNum2;
275 extern UINT32 g_semID;
276 extern UINT32 g_semID2;
277 extern UINT32 g_mutexTest;
278 extern UINT32 g_cpupTestCount;
279 extern UINT16 g_swTmrID;
280 extern UINT32 g_semID;
281 extern UINT32 g_testQueueID01;
282 extern UINT32 g_testQueueID02;
283 extern UINT32 g_testQueueID03;
284 extern UINT32 g_testTskHandle;
285 extern UINT32 g_leavingTaskNum;
286 extern UINT32 g_mAuwTestTaskID[32];
287 extern UINT8 g_mUsIndex;
288 extern UINT32 g_usSemID3[];
289 extern UINT32 g_testPeriod;
290 extern BOOL g_isAddArray;
291 extern BOOL g_isSpinorInit;
292 extern BOOL g_isSdInit;
293 extern UINT32 g_getTickConsume;
294 extern UINT32 g_waitTestCount;
295 extern INT32 g_libFilesystem;
296
297 extern UINT32 GetTimer2Value(VOID);
298 extern int hinand_erase(unsigned long start, unsigned long size);
299 #define hispinor_erase(start, size) \
300 do { \
301 struct erase_info opts; \
302 struct mtd_info *pstMtd; \
303 pstMtd = get_mtd("spinor"); \
304 (void)memset_s(&opts, sizeof(opts), 0, sizeof(opts)); \
305 opts.addr = start; \
306 opts.len = size; \
307 pstMtd->erase(pstMtd, &opts); \
308 } while (0)
309 extern void ipc_gmac_init(void);
310
311 extern UINT32 Mem_Consume_Show(void);
312 extern VOID shell_cmd_register(void);
313 extern INT32 OsShellCmdSystemInfo(INT32 argc, const CHAR **argv);
314 extern UINT32 OsShellCmdDumpTask(INT32 argc, const CHAR **argv);
315 extern UINT32 OsShellCmdTaskCntGet(VOID);
316 extern UINT32 OsShellCmdSwtmrCntGet(VOID);
317 extern void msleep(unsigned int msecs);
318 extern unsigned int sleep(unsigned int seconds);
319 extern int usleep(unsigned useconds);
320
321 extern VOID ipc_network_init(void);
322 #ifdef LOSCFG_DRIVERS_MMC
323 extern INT32 SD_MMC_Host_init(void);
324 #endif
325 extern VOID rdk_fs_init(void);
326 extern VOID jffs2_fs_init(void);
327 extern VOID ProcFsInit(void);
328
329 extern UINT32 LOS_MemTotalUsedGet(VOID *pool);
330 extern VOID ptestTickConsume(VOID);
331 extern UINT32 TEST_TskDelete(UINT32 taskID);
332 extern UINT32 TEST_SemDelete(UINT32 semHandle);
333 extern VOID irq_trigger(unsigned int irq);
334 extern VOID TestPartInit(char *type, UINT32 startAddr, UINT32 length);
335 extern VOID TestPartDelete(char *type);
336
337 extern VOID TestRunShell(VOID);
338
339 extern VOID It_Usb_AutoTest(VOID);
340 extern VOID Test_hid_dev_mode(VOID);
341
342 extern UINT32 usbshell_cmd_reg(VOID);
343 extern void usbshell_queue_control(VOID);
344 extern UINT32 OsTestInit(VOID);
345
346 extern void TEST_DT_COMMON(void);
347
348 extern void it_process_testcase(void);
349 extern void it_pthread_testcase(void);
350 extern void it_mutex_test(void);
351 extern void it_rwlock_test(void);
352 extern void it_spinlock_test(void);
353
354 /* Format options (3rd argument of f_mkfs) */
355 #define TEST_FM_FAT 0x01
356 #define TEST_FM_FAT32 0x02
357 #define TEST_FM_EXFAT 0x04
358 #define TEST_FM_ANY 0x07
359 #define TEST_FM_SFD 0x08
360
361 #define BIG_FD 512
362 typedef struct testrunParam {
363 CHAR testcase_sequence[16];
364 CHAR testcase_num[16];
365 CHAR testcase_layer[32];
366 CHAR testcase_module[32];
367 CHAR testcase_level[16];
368 CHAR testcase_type[16];
369 CHAR testcase_id[128];
370 } TEST_RUN_PARAM;
371
372 typedef enum test_type {
373 HOST_U, // USB U PERFORMANCE
374 HOST_MUTIL, // MUTIL
375 HOST_DISK, // USB DISKPARTION
376 HOST_HUB, // USB HUB
377 HOST_ETH, // USB HOST ETH
378 USB_SMP,
379 HOST_UVC, // USB HOST UVC
380 HOST_NULL
381 } usb_test_type;
382
383
384 #define SHELLTEST_QUEUE_BUFSIZE sizeof(TEST_RUN_PARAM)
385 #ifdef LOSCFG_DRIVERS_USB
386
387 void Test_usb_shellcmd(controller_type ctype, device_type dtype, usb_test_type typetest);
388 #endif
389
390 extern int Gettid(void);
391
392 /* like the ctime/asctime api, use static buffer, though not thread-safe. */
Curtime()393 static inline const char *Curtime()
394 {
395 struct timespec ts;
396 struct tm t;
397 static char buf[32];
398 (void)clock_gettime(CLOCK_REALTIME, &ts);
399 (void)localtime_r(&ts.tv_sec, &t);
400 (void)sprintf_s(buf, sizeof(buf), "%d-%02d-%02d %02d:%02d:%02d.%06ld", t.tm_year + 1900, t.tm_mon + 1, t.tm_mday, t.tm_hour,
401 t.tm_min, t.tm_sec, ts.tv_nsec / 1000);
402 return buf;
403 }
404
405 #define LogPrintln(fmt, ...) \
406 printf("%s [%d] %s:%d " fmt "%c", Curtime(), Gettid(), __FILE__, __LINE__, ##__VA_ARGS__, \
407 ('\n' == " " fmt[sizeof(" " fmt) - 2]) ? '\0' : '\n') // trailing newline is auto appended
408
409 #if !_REDIR_TIME64 || defined(__LP64__)
410 #define TIME_F "ld"
411 #else
412 #define TIME_F "lld"
413 #endif
414
noprintf(...)415 static void noprintf (...)
416 {
417 return;
418 }
419 #define TEST_PRINT printf
420
421 /* the files with different access privilege used in testcases are define below */
422 #define FILEPATH_ENOENT "/storage/test_nosuchfile.txt"
423 #define FILEPATHLEN_ENOENT (strlen(FILEPATH_ENOENT) +1U)
424
425 #define FILEPATH_NOACCESS "noaccessssssssssssssssssssssssssssssssssssssssssss"
426 #define FILEPATHLEN_NOACCESS (strlen(FILEPATH_NOACCESS) +1U)
427
428 #define FILEPATH_000 "/storage/test_000.txt"
429 #define FILEPATHLEN_000 (strlen(FILEPATH_000) +1U)
430
431 #define FILEPATH_775 "/storage/test_775.txt"
432 #define FILEPATHLEN_775 (strlen(FILEPATH_775) +1U)
433
434 #define FILEPATH_755 "/storage/test_775.txt"
435 #define FILEPATHLEN_755 (strlen(FILEPATH_755) +1U)
436
437 #define FILEPATH_RELATIVE "./1.txt"
438 #define FILEPATHLEN_RELATIVE (strlen(FILEPATH_RELATIVE) +1U)
439
440 #define DIRPATH_775 "/storage"
441
442 #define FD_EBADF 513
443 #define FD_EFAULT -1000
444
445 #define PATHNAME_ENAMETOOLONG "ENAMETOOLONG12345678912345678912345678912345678912345678912345678912345678911111\
446 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
447 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
448 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
449 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
450 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
451 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
452 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
453 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
454 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
455 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
456 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
457 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
458 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
459 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
460 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
461 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
462 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
463 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
464 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
465 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
466 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
467 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
468 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
469 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
470 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
471 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
472 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
473 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
474 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
475 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
476 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
477 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
478 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
479 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
480 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
481 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
482 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
483 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
484 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
485 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
486 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
487 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
488 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
489 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
490 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
491 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
492 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
493 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
494 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
495 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
496 12345678912345678912345678913245678912345678912345678913245678913456789123456789\
497 12345678912345678912345678913245678912345678912345678913245678913456789123456789"
498
499 #endif /* _OSTEST_H */
500