tgtinfo.c
上传用户:baixin
上传日期:2008-03-13
资源大小:4795k
文件大小:3k
开发平台:

MultiPlatform

  1. /* tgtinfo.c - xdr routine for coding/decoding a wdbTgtInfo_t */
  2. /* Copyright 1994-1998 Wind River Systems, Inc. */
  3. #include "copyright_wrs.h"
  4. /*
  5. modification history
  6. --------------------
  7. 01g,09may01,dtr  Replacing hasFpp and HasAltivec with hasCoprocessor.
  8. 01f,06feb01,dtr  Adding altivec probe hasAltivec.
  9. 01e,22jan98,c_c  Removed EXT_FUNC references.
  10. 01d,30jan96,elp added windll.h, changed xdr_TGT_ADDR_T in macro.
  11. 01c,10jun95,pad Included rpc/rpc.h. Fixed history.
  12. 01b,04apr95,ms  new data types.
  13. 01a,03oct94,ms generated by rpcgen.
  14. */
  15. /*
  16. DESCRIPTION
  17. This module contains the eXternal Data Representation (XDR) routine
  18. for the wdbVal_t structure of the WDB protocol.
  19. */
  20. /* includes */
  21. #include <rpc/rpc.h>
  22. #include "wdbP.h"
  23. /******************************************************************************
  24. *
  25. * xdr_WDB_RT_INFO -
  26. */ 
  27. BOOL xdr_WDB_RT_INFO
  28.     (
  29.     XDR * xdrs,
  30.     WDB_RT_INFO * objp
  31.     )
  32.     {
  33.     if (!xdr_enum (xdrs, (enum_t *)&objp->rtType))
  34. return (FALSE);
  35.     if (!xdr_WDB_STRING_T (xdrs, &objp->rtVersion))
  36. return (FALSE);
  37.     if (!xdr_TGT_INT_T (xdrs, &objp->cpuType))
  38. return (FALSE);
  39.     if (!xdr_UINT32 (xdrs,  &objp->hasCoprocessor))
  40. return (FALSE);
  41.     if (!xdr_bool (xdrs, &objp->hasWriteProtect))
  42. return (FALSE);
  43.     if (!xdr_TGT_INT_T (xdrs, &objp->pageSize))
  44. return (FALSE);
  45.     if (!xdr_TGT_INT_T (xdrs, &objp->endian))
  46. return (FALSE);
  47.     if (!xdr_WDB_STRING_T (xdrs, &objp->bspName))
  48. return (FALSE);
  49.     if (!xdr_WDB_STRING_T (xdrs, &objp->bootline))
  50. return (FALSE);
  51.     if (!xdr_TGT_ADDR_T (xdrs, &objp->memBase))
  52. return (FALSE);
  53.     if (!xdr_UINT32 (xdrs, &objp->memSize))
  54. return (FALSE);
  55.     if (!xdr_TGT_INT_T (xdrs, &objp->numRegions))
  56. return (FALSE);
  57.     if (!xdr_ARRAY (xdrs, (char **)&objp->memRegion, &objp->numRegions,
  58.                objp->numRegions, sizeof (WDB_MEM_REGION), xdr_WDB_MEM_REGION))
  59.             return (FALSE);
  60.     if (!xdr_TGT_ADDR_T (xdrs, &objp->hostPoolBase))
  61. return (FALSE);
  62.     if (!xdr_UINT32 (xdrs, &objp->hostPoolSize))
  63. return (FALSE);
  64.     return (TRUE);
  65.     }
  66. /******************************************************************************
  67. *
  68. * xdr_WDB_AGENT_INFO -
  69. */ 
  70. BOOL xdr_WDB_AGENT_INFO
  71.     (
  72.     XDR * xdrs,
  73.     WDB_AGENT_INFO * objp
  74.     )
  75.     {
  76.     if (!xdr_WDB_STRING_T (xdrs, &objp->agentVersion))
  77. return (FALSE);
  78.     if (!xdr_TGT_INT_T (xdrs, &objp->mtu))
  79. return (FALSE);
  80.     if (!xdr_TGT_INT_T (xdrs, &objp->mode))
  81. return (FALSE);
  82.     return (TRUE);
  83.     }
  84. /******************************************************************************
  85. *
  86. * xdr_WDB_TGT_INFO -
  87. */ 
  88. BOOL xdr_WDB_TGT_INFO
  89.     (
  90.     XDR * xdrs,
  91.     WDB_TGT_INFO * objp
  92.     )
  93.     {
  94.     if (!xdr_WDB_AGENT_INFO (xdrs, &objp->agentInfo))
  95. return (FALSE);
  96.     if (!xdr_WDB_RT_INFO (xdrs, &objp->rtInfo))
  97. return (FALSE);
  98.     return (TRUE);
  99.     }