home *** CD-ROM | disk | FTP | other *** search
/ Fresh Fish 4 / FreshFish_May-June1994.bin / bbs / cbm / os-include.lha / os-include / inline / graphics.h < prev    next >
C/C++ Source or Header  |  1993-12-09  |  75KB  |  2,234 lines

  1. #ifndef _INLINE_GRAPHICS_H
  2. #define _INLINE_GRAPHICS_H
  3.  
  4. #include <sys/cdefs.h>
  5. #include <inline/stubs.h>
  6.  
  7. __BEGIN_DECLS
  8.  
  9. #ifndef BASE_EXT_DECL
  10. #define BASE_EXT_DECL extern struct GfxBase*  GfxBase;
  11. #endif
  12. #ifndef BASE_PAR_DECL
  13. #define BASE_PAR_DECL
  14. #define BASE_PAR_DECL0 void
  15. #endif
  16. #ifndef BASE_NAME
  17. #define BASE_NAME GfxBase
  18. #endif
  19.  
  20. static __inline void 
  21. AddAnimOb (BASE_PAR_DECL struct AnimOb *anOb,struct AnimOb **anKey,struct RastPort *rp)
  22. {
  23.   BASE_EXT_DECL
  24.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  25.   register struct AnimOb *a0 __asm("a0") = anOb;
  26.   register struct AnimOb **a1 __asm("a1") = anKey;
  27.   register struct RastPort *a2 __asm("a2") = rp;
  28.   __asm __volatile ("jsr a6@(-0x9c)"
  29.   : /* no output */
  30.   : "r" (a6), "r" (a0), "r" (a1), "r" (a2)
  31.   : "a0","a1","a2","d0","d1", "memory");
  32. }
  33. static __inline void 
  34. AddBob (BASE_PAR_DECL struct Bob *bob,struct RastPort *rp)
  35. {
  36.   BASE_EXT_DECL
  37.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  38.   register struct Bob *a0 __asm("a0") = bob;
  39.   register struct RastPort *a1 __asm("a1") = rp;
  40.   __asm __volatile ("jsr a6@(-0x60)"
  41.   : /* no output */
  42.   : "r" (a6), "r" (a0), "r" (a1)
  43.   : "a0","a1","d0","d1", "memory");
  44. }
  45. static __inline void 
  46. AddFont (BASE_PAR_DECL struct TextFont *textFont)
  47. {
  48.   BASE_EXT_DECL
  49.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  50.   register struct TextFont *a1 __asm("a1") = textFont;
  51.   __asm __volatile ("jsr a6@(-0x1e0)"
  52.   : /* no output */
  53.   : "r" (a6), "r" (a1)
  54.   : "a0","a1","d0","d1", "memory");
  55. }
  56. static __inline void 
  57. AddVSprite (BASE_PAR_DECL struct VSprite *vSprite,struct RastPort *rp)
  58. {
  59.   BASE_EXT_DECL
  60.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  61.   register struct VSprite *a0 __asm("a0") = vSprite;
  62.   register struct RastPort *a1 __asm("a1") = rp;
  63.   __asm __volatile ("jsr a6@(-0x66)"
  64.   : /* no output */
  65.   : "r" (a6), "r" (a0), "r" (a1)
  66.   : "a0","a1","d0","d1", "memory");
  67. }
  68. static __inline struct BitMap *
  69. AllocBitMap (BASE_PAR_DECL unsigned long sizex,unsigned long sizey,unsigned long depth,unsigned long flags,struct BitMap *friend_bitmap)
  70. {
  71.   BASE_EXT_DECL
  72.   register struct BitMap * _res  __asm("d0");
  73.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  74.   register unsigned long d0 __asm("d0") = sizex;
  75.   register unsigned long d1 __asm("d1") = sizey;
  76.   register unsigned long d2 __asm("d2") = depth;
  77.   register unsigned long d3 __asm("d3") = flags;
  78.   register struct BitMap *a0 __asm("a0") = friend_bitmap;
  79.   __asm __volatile ("jsr a6@(-0x396)"
  80.   : "=r" (_res)
  81.   : "r" (a6), "r" (d0), "r" (d1), "r" (d2), "r" (d3), "r" (a0)
  82.   : "a0","a1","d0","d1","d2","d3", "memory");
  83.   return _res;
  84. }
  85. static __inline struct DBufInfo *
  86. AllocDBufInfo (BASE_PAR_DECL struct ViewPort *vp)
  87. {
  88.   BASE_EXT_DECL
  89.   register struct DBufInfo * _res  __asm("d0");
  90.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  91.   register struct ViewPort *a0 __asm("a0") = vp;
  92.   __asm __volatile ("jsr a6@(-0x3c6)"
  93.   : "=r" (_res)
  94.   : "r" (a6), "r" (a0)
  95.   : "a0","a1","d0","d1", "memory");
  96.   return _res;
  97. }
  98. static __inline PLANEPTR 
  99. AllocRaster (BASE_PAR_DECL unsigned long width,unsigned long height)
  100. {
  101.   BASE_EXT_DECL
  102.   register PLANEPTR  _res  __asm("d0");
  103.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  104.   register unsigned long d0 __asm("d0") = width;
  105.   register unsigned long d1 __asm("d1") = height;
  106.   __asm __volatile ("jsr a6@(-0x1ec)"
  107.   : "=r" (_res)
  108.   : "r" (a6), "r" (d0), "r" (d1)
  109.   : "a0","a1","d0","d1", "memory");
  110.   return _res;
  111. }
  112. static __inline struct ExtSprite *
  113. AllocSpriteDataA (BASE_PAR_DECL struct BitMap *bm,struct TagItem *tags)
  114. {
  115.   BASE_EXT_DECL
  116.   register struct ExtSprite * _res  __asm("d0");
  117.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  118.   register struct BitMap *a2 __asm("a2") = bm;
  119.   register struct TagItem *a1 __asm("a1") = tags;
  120.   __asm __volatile ("jsr a6@(-0x3fc)"
  121.   : "=r" (_res)
  122.   : "r" (a6), "r" (a2), "r" (a1)
  123.   : "a0","a1","a2","d0","d1", "memory");
  124.   return _res;
  125. }
  126. static __inline void 
  127. AndRectRegion (BASE_PAR_DECL struct Region *region,struct Rectangle *rectangle)
  128. {
  129.   BASE_EXT_DECL
  130.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  131.   register struct Region *a0 __asm("a0") = region;
  132.   register struct Rectangle *a1 __asm("a1") = rectangle;
  133.   __asm __volatile ("jsr a6@(-0x1f8)"
  134.   : /* no output */
  135.   : "r" (a6), "r" (a0), "r" (a1)
  136.   : "a0","a1","d0","d1", "memory");
  137. }
  138. static __inline BOOL 
  139. AndRegionRegion (BASE_PAR_DECL struct Region *srcRegion,struct Region *destRegion)
  140. {
  141.   BASE_EXT_DECL
  142.   register BOOL  _res  __asm("d0");
  143.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  144.   register struct Region *a0 __asm("a0") = srcRegion;
  145.   register struct Region *a1 __asm("a1") = destRegion;
  146.   __asm __volatile ("jsr a6@(-0x270)"
  147.   : "=r" (_res)
  148.   : "r" (a6), "r" (a0), "r" (a1)
  149.   : "a0","a1","d0","d1", "memory");
  150.   return _res;
  151. }
  152. static __inline void 
  153. Animate (BASE_PAR_DECL struct AnimOb **anKey,struct RastPort *rp)
  154. {
  155.   BASE_EXT_DECL
  156.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  157.   register struct AnimOb **a0 __asm("a0") = anKey;
  158.   register struct RastPort *a1 __asm("a1") = rp;
  159.   __asm __volatile ("jsr a6@(-0xa2)"
  160.   : /* no output */
  161.   : "r" (a6), "r" (a0), "r" (a1)
  162.   : "a0","a1","d0","d1", "memory");
  163. }
  164. static __inline LONG 
  165. AreaDraw (BASE_PAR_DECL struct RastPort *rp,long x,long y)
  166. {
  167.   BASE_EXT_DECL
  168.   register LONG  _res  __asm("d0");
  169.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  170.   register struct RastPort *a1 __asm("a1") = rp;
  171.   register long d0 __asm("d0") = x;
  172.   register long d1 __asm("d1") = y;
  173.   __asm __volatile ("jsr a6@(-0x102)"
  174.   : "=r" (_res)
  175.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  176.   : "a0","a1","d0","d1", "memory");
  177.   return _res;
  178. }
  179. static __inline LONG 
  180. AreaEllipse (BASE_PAR_DECL struct RastPort *rp,long xCenter,long yCenter,long a,long b)
  181. {
  182.   BASE_EXT_DECL
  183.   register LONG  _res  __asm("d0");
  184.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  185.   register struct RastPort *a1 __asm("a1") = rp;
  186.   register long d0 __asm("d0") = xCenter;
  187.   register long d1 __asm("d1") = yCenter;
  188.   register long d2 __asm("d2") = a;
  189.   register long d3 __asm("d3") = b;
  190.   __asm __volatile ("jsr a6@(-0xba)"
  191.   : "=r" (_res)
  192.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1), "r" (d2), "r" (d3)
  193.   : "a0","a1","d0","d1","d2","d3", "memory");
  194.   return _res;
  195. }
  196. static __inline LONG 
  197. AreaEnd (BASE_PAR_DECL struct RastPort *rp)
  198. {
  199.   BASE_EXT_DECL
  200.   register LONG  _res  __asm("d0");
  201.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  202.   register struct RastPort *a1 __asm("a1") = rp;
  203.   __asm __volatile ("jsr a6@(-0x108)"
  204.   : "=r" (_res)
  205.   : "r" (a6), "r" (a1)
  206.   : "a0","a1","d0","d1", "memory");
  207.   return _res;
  208. }
  209. static __inline LONG 
  210. AreaMove (BASE_PAR_DECL struct RastPort *rp,long x,long y)
  211. {
  212.   BASE_EXT_DECL
  213.   register LONG  _res  __asm("d0");
  214.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  215.   register struct RastPort *a1 __asm("a1") = rp;
  216.   register long d0 __asm("d0") = x;
  217.   register long d1 __asm("d1") = y;
  218.   __asm __volatile ("jsr a6@(-0xfc)"
  219.   : "=r" (_res)
  220.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  221.   : "a0","a1","d0","d1", "memory");
  222.   return _res;
  223. }
  224. static __inline void 
  225. AskFont (BASE_PAR_DECL struct RastPort *rp,struct TextAttr *textAttr)
  226. {
  227.   BASE_EXT_DECL
  228.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  229.   register struct RastPort *a1 __asm("a1") = rp;
  230.   register struct TextAttr *a0 __asm("a0") = textAttr;
  231.   __asm __volatile ("jsr a6@(-0x1da)"
  232.   : /* no output */
  233.   : "r" (a6), "r" (a1), "r" (a0)
  234.   : "a0","a1","d0","d1", "memory");
  235. }
  236. static __inline ULONG 
  237. AskSoftStyle (BASE_PAR_DECL struct RastPort *rp)
  238. {
  239.   BASE_EXT_DECL
  240.   register ULONG  _res  __asm("d0");
  241.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  242.   register struct RastPort *a1 __asm("a1") = rp;
  243.   __asm __volatile ("jsr a6@(-0x54)"
  244.   : "=r" (_res)
  245.   : "r" (a6), "r" (a1)
  246.   : "a0","a1","d0","d1", "memory");
  247.   return _res;
  248. }
  249. static __inline LONG 
  250. AttachPalExtra (BASE_PAR_DECL struct ColorMap *cm,struct ViewPort *vp)
  251. {
  252.   BASE_EXT_DECL
  253.   register LONG  _res  __asm("d0");
  254.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  255.   register struct ColorMap *a0 __asm("a0") = cm;
  256.   register struct ViewPort *a1 __asm("a1") = vp;
  257.   __asm __volatile ("jsr a6@(-0x342)"
  258.   : "=r" (_res)
  259.   : "r" (a6), "r" (a0), "r" (a1)
  260.   : "a0","a1","d0","d1", "memory");
  261.   return _res;
  262. }
  263. static __inline BOOL 
  264. AttemptLockLayerRom (BASE_PAR_DECL struct Layer *layer)
  265. {
  266.   BASE_EXT_DECL
  267.   register BOOL  _res  __asm("d0");
  268.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  269.   register struct Layer *a5 __asm("a5") = layer;
  270.   __asm __volatile ("jsr a6@(-0x28e)"
  271.   : "=r" (_res)
  272.   : "r" (a6), "r" (a5)
  273.   : "a0","a1","a5","d0","d1", "memory");
  274.   return _res;
  275. }
  276. static __inline ULONG 
  277. BestModeIDA (BASE_PAR_DECL struct TagItem *tags)
  278. {
  279.   BASE_EXT_DECL
  280.   register ULONG  _res  __asm("d0");
  281.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  282.   register struct TagItem *a0 __asm("a0") = tags;
  283.   __asm __volatile ("jsr a6@(-0x41a)"
  284.   : "=r" (_res)
  285.   : "r" (a6), "r" (a0)
  286.   : "a0","a1","d0","d1", "memory");
  287.   return _res;
  288. }
  289. static __inline void 
  290. BitMapScale (BASE_PAR_DECL struct BitScaleArgs *bitScaleArgs)
  291. {
  292.   BASE_EXT_DECL
  293.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  294.   register struct BitScaleArgs *a0 __asm("a0") = bitScaleArgs;
  295.   __asm __volatile ("jsr a6@(-0x2a6)"
  296.   : /* no output */
  297.   : "r" (a6), "r" (a0)
  298.   : "a0","a1","d0","d1", "memory");
  299. }
  300. static __inline LONG 
  301. BltBitMap (BASE_PAR_DECL struct BitMap *srcBitMap,long xSrc,long ySrc,struct BitMap *destBitMap,long xDest,long yDest,long xSize,long ySize,unsigned long minterm,unsigned long mask,PLANEPTR tempA)
  302. {
  303.   BASE_EXT_DECL
  304.   register LONG  _res  __asm("d0");
  305.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  306.   register struct BitMap *a0 __asm("a0") = srcBitMap;
  307.   register long d0 __asm("d0") = xSrc;
  308.   register long d1 __asm("d1") = ySrc;
  309.   register struct BitMap *a1 __asm("a1") = destBitMap;
  310.   register long d2 __asm("d2") = xDest;
  311.   register long d3 __asm("d3") = yDest;
  312.   register long d4 __asm("d4") = xSize;
  313.   register long d5 __asm("d5") = ySize;
  314.   register unsigned long d6 __asm("d6") = minterm;
  315.   register unsigned long d7 __asm("d7") = mask;
  316.   register PLANEPTR a2 __asm("a2") = tempA;
  317.   __asm __volatile ("jsr a6@(-0x1e)"
  318.   : "=r" (_res)
  319.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (a1), "r" (d2), "r" (d3), "r" (d4), "r" (d5), "r" (d6), "r" (d7), "r" (a2)
  320.   : "a0","a1","a2","d0","d1","d2","d3","d4","d5","d6","d7", "memory");
  321.   return _res;
  322. }
  323. static __inline void 
  324. BltBitMapRastPort (BASE_PAR_DECL struct BitMap *srcBitMap,long xSrc,long ySrc,struct RastPort *destRP,long xDest,long yDest,long xSize,long ySize,unsigned long minterm)
  325. {
  326.   BASE_EXT_DECL
  327.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  328.   register struct BitMap *a0 __asm("a0") = srcBitMap;
  329.   register long d0 __asm("d0") = xSrc;
  330.   register long d1 __asm("d1") = ySrc;
  331.   register struct RastPort *a1 __asm("a1") = destRP;
  332.   register long d2 __asm("d2") = xDest;
  333.   register long d3 __asm("d3") = yDest;
  334.   register long d4 __asm("d4") = xSize;
  335.   register long d5 __asm("d5") = ySize;
  336.   register unsigned long d6 __asm("d6") = minterm;
  337.   __asm __volatile ("jsr a6@(-0x25e)"
  338.   : /* no output */
  339.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (a1), "r" (d2), "r" (d3), "r" (d4), "r" (d5), "r" (d6)
  340.   : "a0","a1","d0","d1","d2","d3","d4","d5","d6", "memory");
  341. }
  342. static __inline void 
  343. BltClear (BASE_PAR_DECL PLANEPTR memBlock,unsigned long byteCount,unsigned long flags)
  344. {
  345.   BASE_EXT_DECL
  346.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  347.   register PLANEPTR a1 __asm("a1") = memBlock;
  348.   register unsigned long d0 __asm("d0") = byteCount;
  349.   register unsigned long d1 __asm("d1") = flags;
  350.   __asm __volatile ("jsr a6@(-0x12c)"
  351.   : /* no output */
  352.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  353.   : "a0","a1","d0","d1", "memory");
  354. }
  355. static __inline void 
  356. BltMaskBitMapRastPort (BASE_PAR_DECL struct BitMap *srcBitMap,long xSrc,long ySrc,struct RastPort *destRP,long xDest,long yDest,long xSize,long ySize,unsigned long minterm,PLANEPTR bltMask)
  357. {
  358.   BASE_EXT_DECL
  359.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  360.   register struct BitMap *a0 __asm("a0") = srcBitMap;
  361.   register long d0 __asm("d0") = xSrc;
  362.   register long d1 __asm("d1") = ySrc;
  363.   register struct RastPort *a1 __asm("a1") = destRP;
  364.   register long d2 __asm("d2") = xDest;
  365.   register long d3 __asm("d3") = yDest;
  366.   register long d4 __asm("d4") = xSize;
  367.   register long d5 __asm("d5") = ySize;
  368.   register unsigned long d6 __asm("d6") = minterm;
  369.   register PLANEPTR a2 __asm("a2") = bltMask;
  370.   __asm __volatile ("jsr a6@(-0x27c)"
  371.   : /* no output */
  372.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (a1), "r" (d2), "r" (d3), "r" (d4), "r" (d5), "r" (d6), "r" (a2)
  373.   : "a0","a1","a2","d0","d1","d2","d3","d4","d5","d6", "memory");
  374. }
  375. static __inline void 
  376. BltPattern (BASE_PAR_DECL struct RastPort *rp,PLANEPTR mask,long xMin,long yMin,long xMax,long yMax,unsigned long maskBPR)
  377. {
  378.   BASE_EXT_DECL
  379.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  380.   register struct RastPort *a1 __asm("a1") = rp;
  381.   register PLANEPTR a0 __asm("a0") = mask;
  382.   register long d0 __asm("d0") = xMin;
  383.   register long d1 __asm("d1") = yMin;
  384.   register long d2 __asm("d2") = xMax;
  385.   register long d3 __asm("d3") = yMax;
  386.   register unsigned long d4 __asm("d4") = maskBPR;
  387.   __asm __volatile ("jsr a6@(-0x138)"
  388.   : /* no output */
  389.   : "r" (a6), "r" (a1), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3), "r" (d4)
  390.   : "a0","a1","d0","d1","d2","d3","d4", "memory");
  391. }
  392. static __inline void 
  393. BltTemplate (BASE_PAR_DECL PLANEPTR source,long xSrc,long srcMod,struct RastPort *destRP,long xDest,long yDest,long xSize,long ySize)
  394. {
  395.   BASE_EXT_DECL
  396.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  397.   register PLANEPTR a0 __asm("a0") = source;
  398.   register long d0 __asm("d0") = xSrc;
  399.   register long d1 __asm("d1") = srcMod;
  400.   register struct RastPort *a1 __asm("a1") = destRP;
  401.   register long d2 __asm("d2") = xDest;
  402.   register long d3 __asm("d3") = yDest;
  403.   register long d4 __asm("d4") = xSize;
  404.   register long d5 __asm("d5") = ySize;
  405.   __asm __volatile ("jsr a6@(-0x24)"
  406.   : /* no output */
  407.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (a1), "r" (d2), "r" (d3), "r" (d4), "r" (d5)
  408.   : "a0","a1","d0","d1","d2","d3","d4","d5", "memory");
  409. }
  410. static __inline void 
  411. CBump (BASE_PAR_DECL struct UCopList *copList)
  412. {
  413.   BASE_EXT_DECL
  414.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  415.   register struct UCopList *a1 __asm("a1") = copList;
  416.   __asm __volatile ("jsr a6@(-0x16e)"
  417.   : /* no output */
  418.   : "r" (a6), "r" (a1)
  419.   : "a0","a1","d0","d1", "memory");
  420. }
  421. static __inline void 
  422. CMove (BASE_PAR_DECL struct UCopList *copList,APTR destination,long data)
  423. {
  424.   BASE_EXT_DECL
  425.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  426.   register struct UCopList *a1 __asm("a1") = copList;
  427.   register APTR d0 __asm("d0") = destination;
  428.   register long d1 __asm("d1") = data;
  429.   __asm __volatile ("jsr a6@(-0x174)"
  430.   : /* no output */
  431.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  432.   : "a0","a1","d0","d1", "memory");
  433. }
  434. static __inline void 
  435. CWait (BASE_PAR_DECL struct UCopList *copList,long v,long h)
  436. {
  437.   BASE_EXT_DECL
  438.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  439.   register struct UCopList *a1 __asm("a1") = copList;
  440.   register long d0 __asm("d0") = v;
  441.   register long d1 __asm("d1") = h;
  442.   __asm __volatile ("jsr a6@(-0x17a)"
  443.   : /* no output */
  444.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  445.   : "a0","a1","d0","d1", "memory");
  446. }
  447. static __inline UWORD 
  448. CalcIVG (BASE_PAR_DECL struct View *v,struct ViewPort *vp)
  449. {
  450.   BASE_EXT_DECL
  451.   register UWORD  _res  __asm("d0");
  452.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  453.   register struct View *a0 __asm("a0") = v;
  454.   register struct ViewPort *a1 __asm("a1") = vp;
  455.   __asm __volatile ("jsr a6@(-0x33c)"
  456.   : "=r" (_res)
  457.   : "r" (a6), "r" (a0), "r" (a1)
  458.   : "a0","a1","d0","d1", "memory");
  459.   return _res;
  460. }
  461. static __inline LONG 
  462. ChangeExtSpriteA (BASE_PAR_DECL struct ViewPort *vp,struct ExtSprite *oldsprite,struct ExtSprite *newsprite,struct TagItem *tags)
  463. {
  464.   BASE_EXT_DECL
  465.   register LONG  _res  __asm("d0");
  466.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  467.   register struct ViewPort *a0 __asm("a0") = vp;
  468.   register struct ExtSprite *a1 __asm("a1") = oldsprite;
  469.   register struct ExtSprite *a2 __asm("a2") = newsprite;
  470.   register struct TagItem *a3 __asm("a3") = tags;
  471.   __asm __volatile ("jsr a6@(-0x402)"
  472.   : "=r" (_res)
  473.   : "r" (a6), "r" (a0), "r" (a1), "r" (a2), "r" (a3)
  474.   : "a0","a1","a2","a3","d0","d1", "memory");
  475.   return _res;
  476. }
  477. static __inline void 
  478. ChangeSprite (BASE_PAR_DECL struct ViewPort *vp,struct SimpleSprite *sprite,PLANEPTR newData)
  479. {
  480.   BASE_EXT_DECL
  481.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  482.   register struct ViewPort *a0 __asm("a0") = vp;
  483.   register struct SimpleSprite *a1 __asm("a1") = sprite;
  484.   register PLANEPTR a2 __asm("a2") = newData;
  485.   __asm __volatile ("jsr a6@(-0x1a4)"
  486.   : /* no output */
  487.   : "r" (a6), "r" (a0), "r" (a1), "r" (a2)
  488.   : "a0","a1","a2","d0","d1", "memory");
  489. }
  490. static __inline void 
  491. ChangeVPBitMap (BASE_PAR_DECL struct ViewPort *vp,struct BitMap *bm,struct DBufInfo *db)
  492. {
  493.   BASE_EXT_DECL
  494.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  495.   register struct ViewPort *a0 __asm("a0") = vp;
  496.   register struct BitMap *a1 __asm("a1") = bm;
  497.   register struct DBufInfo *a2 __asm("a2") = db;
  498.   __asm __volatile ("jsr a6@(-0x3ae)"
  499.   : /* no output */
  500.   : "r" (a6), "r" (a0), "r" (a1), "r" (a2)
  501.   : "a0","a1","a2","d0","d1", "memory");
  502. }
  503. static __inline void 
  504. ClearEOL (BASE_PAR_DECL struct RastPort *rp)
  505. {
  506.   BASE_EXT_DECL
  507.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  508.   register struct RastPort *a1 __asm("a1") = rp;
  509.   __asm __volatile ("jsr a6@(-0x2a)"
  510.   : /* no output */
  511.   : "r" (a6), "r" (a1)
  512.   : "a0","a1","d0","d1", "memory");
  513. }
  514. static __inline BOOL 
  515. ClearRectRegion (BASE_PAR_DECL struct Region *region,struct Rectangle *rectangle)
  516. {
  517.   BASE_EXT_DECL
  518.   register BOOL  _res  __asm("d0");
  519.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  520.   register struct Region *a0 __asm("a0") = region;
  521.   register struct Rectangle *a1 __asm("a1") = rectangle;
  522.   __asm __volatile ("jsr a6@(-0x20a)"
  523.   : "=r" (_res)
  524.   : "r" (a6), "r" (a0), "r" (a1)
  525.   : "a0","a1","d0","d1", "memory");
  526.   return _res;
  527. }
  528. static __inline void 
  529. ClearRegion (BASE_PAR_DECL struct Region *region)
  530. {
  531.   BASE_EXT_DECL
  532.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  533.   register struct Region *a0 __asm("a0") = region;
  534.   __asm __volatile ("jsr a6@(-0x210)"
  535.   : /* no output */
  536.   : "r" (a6), "r" (a0)
  537.   : "a0","a1","d0","d1", "memory");
  538. }
  539. static __inline void 
  540. ClearScreen (BASE_PAR_DECL struct RastPort *rp)
  541. {
  542.   BASE_EXT_DECL
  543.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  544.   register struct RastPort *a1 __asm("a1") = rp;
  545.   __asm __volatile ("jsr a6@(-0x30)"
  546.   : /* no output */
  547.   : "r" (a6), "r" (a1)
  548.   : "a0","a1","d0","d1", "memory");
  549. }
  550. static __inline void 
  551. ClipBlit (BASE_PAR_DECL struct RastPort *srcRP,long xSrc,long ySrc,struct RastPort *destRP,long xDest,long yDest,long xSize,long ySize,unsigned long minterm)
  552. {
  553.   BASE_EXT_DECL
  554.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  555.   register struct RastPort *a0 __asm("a0") = srcRP;
  556.   register long d0 __asm("d0") = xSrc;
  557.   register long d1 __asm("d1") = ySrc;
  558.   register struct RastPort *a1 __asm("a1") = destRP;
  559.   register long d2 __asm("d2") = xDest;
  560.   register long d3 __asm("d3") = yDest;
  561.   register long d4 __asm("d4") = xSize;
  562.   register long d5 __asm("d5") = ySize;
  563.   register unsigned long d6 __asm("d6") = minterm;
  564.   __asm __volatile ("jsr a6@(-0x228)"
  565.   : /* no output */
  566.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (a1), "r" (d2), "r" (d3), "r" (d4), "r" (d5), "r" (d6)
  567.   : "a0","a1","d0","d1","d2","d3","d4","d5","d6", "memory");
  568. }
  569. static __inline void 
  570. CloseFont (BASE_PAR_DECL struct TextFont *textFont)
  571. {
  572.   BASE_EXT_DECL
  573.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  574.   register struct TextFont *a1 __asm("a1") = textFont;
  575.   __asm __volatile ("jsr a6@(-0x4e)"
  576.   : /* no output */
  577.   : "r" (a6), "r" (a1)
  578.   : "a0","a1","d0","d1", "memory");
  579. }
  580. static __inline BOOL 
  581. CloseMonitor (BASE_PAR_DECL struct MonitorSpec *monitorSpec)
  582. {
  583.   BASE_EXT_DECL
  584.   register BOOL  _res  __asm("d0");
  585.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  586.   register struct MonitorSpec *a0 __asm("a0") = monitorSpec;
  587.   __asm __volatile ("jsr a6@(-0x2d0)"
  588.   : "=r" (_res)
  589.   : "r" (a6), "r" (a0)
  590.   : "a0","a1","d0","d1", "memory");
  591.   return _res;
  592. }
  593. static __inline ULONG 
  594. CoerceMode (BASE_PAR_DECL struct ViewPort *vp,unsigned long monitorid,unsigned long flags)
  595. {
  596.   BASE_EXT_DECL
  597.   register ULONG  _res  __asm("d0");
  598.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  599.   register struct ViewPort *a0 __asm("a0") = vp;
  600.   register unsigned long d0 __asm("d0") = monitorid;
  601.   register unsigned long d1 __asm("d1") = flags;
  602.   __asm __volatile ("jsr a6@(-0x3a8)"
  603.   : "=r" (_res)
  604.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1)
  605.   : "a0","a1","d0","d1", "memory");
  606.   return _res;
  607. }
  608. static __inline void 
  609. CopySBitMap (BASE_PAR_DECL struct Layer *layer)
  610. {
  611.   BASE_EXT_DECL
  612.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  613.   register struct Layer *a0 __asm("a0") = layer;
  614.   __asm __volatile ("jsr a6@(-0x1c2)"
  615.   : /* no output */
  616.   : "r" (a6), "r" (a0)
  617.   : "a0","a1","d0","d1", "memory");
  618. }
  619. static __inline void 
  620. DisownBlitter (BASE_PAR_DECL0)
  621. {
  622.   BASE_EXT_DECL
  623.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  624.   __asm __volatile ("jsr a6@(-0x1ce)"
  625.   : /* no output */
  626.   : "r" (a6)
  627.   : "a0","a1","d0","d1", "memory");
  628. }
  629. static __inline void 
  630. DisposeRegion (BASE_PAR_DECL struct Region *region)
  631. {
  632.   BASE_EXT_DECL
  633.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  634.   register struct Region *a0 __asm("a0") = region;
  635.   __asm __volatile ("jsr a6@(-0x216)"
  636.   : /* no output */
  637.   : "r" (a6), "r" (a0)
  638.   : "a0","a1","d0","d1", "memory");
  639. }
  640. static __inline void 
  641. DoCollision (BASE_PAR_DECL struct RastPort *rp)
  642. {
  643.   BASE_EXT_DECL
  644.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  645.   register struct RastPort *a1 __asm("a1") = rp;
  646.   __asm __volatile ("jsr a6@(-0x6c)"
  647.   : /* no output */
  648.   : "r" (a6), "r" (a1)
  649.   : "a0","a1","d0","d1", "memory");
  650. }
  651. static __inline void 
  652. Draw (BASE_PAR_DECL struct RastPort *rp,long x,long y)
  653. {
  654.   BASE_EXT_DECL
  655.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  656.   register struct RastPort *a1 __asm("a1") = rp;
  657.   register long d0 __asm("d0") = x;
  658.   register long d1 __asm("d1") = y;
  659.   __asm __volatile ("jsr a6@(-0xf6)"
  660.   : /* no output */
  661.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  662.   : "a0","a1","d0","d1", "memory");
  663. }
  664. static __inline void 
  665. DrawEllipse (BASE_PAR_DECL struct RastPort *rp,long xCenter,long yCenter,long a,long b)
  666. {
  667.   BASE_EXT_DECL
  668.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  669.   register struct RastPort *a1 __asm("a1") = rp;
  670.   register long d0 __asm("d0") = xCenter;
  671.   register long d1 __asm("d1") = yCenter;
  672.   register long d2 __asm("d2") = a;
  673.   register long d3 __asm("d3") = b;
  674.   __asm __volatile ("jsr a6@(-0xb4)"
  675.   : /* no output */
  676.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1), "r" (d2), "r" (d3)
  677.   : "a0","a1","d0","d1","d2","d3", "memory");
  678. }
  679. static __inline void 
  680. DrawGList (BASE_PAR_DECL struct RastPort *rp,struct ViewPort *vp)
  681. {
  682.   BASE_EXT_DECL
  683.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  684.   register struct RastPort *a1 __asm("a1") = rp;
  685.   register struct ViewPort *a0 __asm("a0") = vp;
  686.   __asm __volatile ("jsr a6@(-0x72)"
  687.   : /* no output */
  688.   : "r" (a6), "r" (a1), "r" (a0)
  689.   : "a0","a1","d0","d1", "memory");
  690. }
  691. static __inline void 
  692. EraseRect (BASE_PAR_DECL struct RastPort *rp,long xMin,long yMin,long xMax,long yMax)
  693. {
  694.   BASE_EXT_DECL
  695.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  696.   register struct RastPort *a1 __asm("a1") = rp;
  697.   register long d0 __asm("d0") = xMin;
  698.   register long d1 __asm("d1") = yMin;
  699.   register long d2 __asm("d2") = xMax;
  700.   register long d3 __asm("d3") = yMax;
  701.   __asm __volatile ("jsr a6@(-0x32a)"
  702.   : /* no output */
  703.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1), "r" (d2), "r" (d3)
  704.   : "a0","a1","d0","d1","d2","d3", "memory");
  705. }
  706. static __inline ULONG 
  707. ExtendFont (BASE_PAR_DECL struct TextFont *font,struct TagItem *fontTags)
  708. {
  709.   BASE_EXT_DECL
  710.   register ULONG  _res  __asm("d0");
  711.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  712.   register struct TextFont *a0 __asm("a0") = font;
  713.   register struct TagItem *a1 __asm("a1") = fontTags;
  714.   __asm __volatile ("jsr a6@(-0x330)"
  715.   : "=r" (_res)
  716.   : "r" (a6), "r" (a0), "r" (a1)
  717.   : "a0","a1","d0","d1", "memory");
  718.   return _res;
  719. }
  720. #ifndef NO_INLINE_STDARG
  721. #define ExtendFontTags(a0, tags...) \
  722.   ({ struct TagItem _tags[] = { tags }; ExtendFont ((a0), _tags); })
  723. #endif /* not NO_INLINE_STDARG */
  724. static __inline LONG 
  725. FindColor (BASE_PAR_DECL struct ColorMap *cm,unsigned long r,unsigned long g,unsigned long b,long maxcolor)
  726. {
  727.   BASE_EXT_DECL
  728.   register LONG  _res  __asm("d0");
  729.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  730.   register struct ColorMap *a3 __asm("a3") = cm;
  731.   register unsigned long d1 __asm("d1") = r;
  732.   register unsigned long d2 __asm("d2") = g;
  733.   register unsigned long d3 __asm("d3") = b;
  734.   register long d4 __asm("d4") = maxcolor;
  735.   __asm __volatile ("jsr a6@(-0x3f0)"
  736.   : "=r" (_res)
  737.   : "r" (a6), "r" (a3), "r" (d1), "r" (d2), "r" (d3), "r" (d4)
  738.   : "a0","a1","a3","d0","d1","d2","d3","d4", "memory");
  739.   return _res;
  740. }
  741. static __inline DisplayInfoHandle 
  742. FindDisplayInfo (BASE_PAR_DECL unsigned long displayID)
  743. {
  744.   BASE_EXT_DECL
  745.   register DisplayInfoHandle  _res  __asm("d0");
  746.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  747.   register unsigned long d0 __asm("d0") = displayID;
  748.   __asm __volatile ("jsr a6@(-0x2d6)"
  749.   : "=r" (_res)
  750.   : "r" (a6), "r" (d0)
  751.   : "a0","a1","d0","d1", "memory");
  752.   return _res;
  753. }
  754. static __inline BOOL 
  755. Flood (BASE_PAR_DECL struct RastPort *rp,unsigned long mode,long x,long y)
  756. {
  757.   BASE_EXT_DECL
  758.   register BOOL  _res  __asm("d0");
  759.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  760.   register struct RastPort *a1 __asm("a1") = rp;
  761.   register unsigned long d2 __asm("d2") = mode;
  762.   register long d0 __asm("d0") = x;
  763.   register long d1 __asm("d1") = y;
  764.   __asm __volatile ("jsr a6@(-0x14a)"
  765.   : "=r" (_res)
  766.   : "r" (a6), "r" (a1), "r" (d2), "r" (d0), "r" (d1)
  767.   : "a0","a1","d0","d1","d2", "memory");
  768.   return _res;
  769. }
  770. static __inline void 
  771. FontExtent (BASE_PAR_DECL struct TextFont *font,struct TextExtent *fontExtent)
  772. {
  773.   BASE_EXT_DECL
  774.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  775.   register struct TextFont *a0 __asm("a0") = font;
  776.   register struct TextExtent *a1 __asm("a1") = fontExtent;
  777.   __asm __volatile ("jsr a6@(-0x2fa)"
  778.   : /* no output */
  779.   : "r" (a6), "r" (a0), "r" (a1)
  780.   : "a0","a1","d0","d1", "memory");
  781. }
  782. static __inline void 
  783. FreeBitMap (BASE_PAR_DECL struct BitMap *bm)
  784. {
  785.   BASE_EXT_DECL
  786.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  787.   register struct BitMap *a0 __asm("a0") = bm;
  788.   __asm __volatile ("jsr a6@(-0x39c)"
  789.   : /* no output */
  790.   : "r" (a6), "r" (a0)
  791.   : "a0","a1","d0","d1", "memory");
  792. }
  793. static __inline void 
  794. FreeColorMap (BASE_PAR_DECL struct ColorMap *colorMap)
  795. {
  796.   BASE_EXT_DECL
  797.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  798.   register struct ColorMap *a0 __asm("a0") = colorMap;
  799.   __asm __volatile ("jsr a6@(-0x240)"
  800.   : /* no output */
  801.   : "r" (a6), "r" (a0)
  802.   : "a0","a1","d0","d1", "memory");
  803. }
  804. static __inline void 
  805. FreeCopList (BASE_PAR_DECL struct CopList *copList)
  806. {
  807.   BASE_EXT_DECL
  808.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  809.   register struct CopList *a0 __asm("a0") = copList;
  810.   __asm __volatile ("jsr a6@(-0x222)"
  811.   : /* no output */
  812.   : "r" (a6), "r" (a0)
  813.   : "a0","a1","d0","d1", "memory");
  814. }
  815. static __inline void 
  816. FreeCprList (BASE_PAR_DECL struct cprlist *cprList)
  817. {
  818.   BASE_EXT_DECL
  819.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  820.   register struct cprlist *a0 __asm("a0") = cprList;
  821.   __asm __volatile ("jsr a6@(-0x234)"
  822.   : /* no output */
  823.   : "r" (a6), "r" (a0)
  824.   : "a0","a1","d0","d1", "memory");
  825. }
  826. static __inline void 
  827. FreeDBufInfo (BASE_PAR_DECL struct DBufInfo *dbi)
  828. {
  829.   BASE_EXT_DECL
  830.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  831.   register struct DBufInfo *a1 __asm("a1") = dbi;
  832.   __asm __volatile ("jsr a6@(-0x3cc)"
  833.   : /* no output */
  834.   : "r" (a6), "r" (a1)
  835.   : "a0","a1","d0","d1", "memory");
  836. }
  837. static __inline void 
  838. FreeGBuffers (BASE_PAR_DECL struct AnimOb *anOb,struct RastPort *rp,long flag)
  839. {
  840.   BASE_EXT_DECL
  841.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  842.   register struct AnimOb *a0 __asm("a0") = anOb;
  843.   register struct RastPort *a1 __asm("a1") = rp;
  844.   register long d0 __asm("d0") = flag;
  845.   __asm __volatile ("jsr a6@(-0x258)"
  846.   : /* no output */
  847.   : "r" (a6), "r" (a0), "r" (a1), "r" (d0)
  848.   : "a0","a1","d0","d1", "memory");
  849. }
  850. static __inline void 
  851. FreeRaster (BASE_PAR_DECL PLANEPTR p,unsigned long width,unsigned long height)
  852. {
  853.   BASE_EXT_DECL
  854.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  855.   register PLANEPTR a0 __asm("a0") = p;
  856.   register unsigned long d0 __asm("d0") = width;
  857.   register unsigned long d1 __asm("d1") = height;
  858.   __asm __volatile ("jsr a6@(-0x1f2)"
  859.   : /* no output */
  860.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1)
  861.   : "a0","a1","d0","d1", "memory");
  862. }
  863. static __inline void 
  864. FreeSprite (BASE_PAR_DECL long num)
  865. {
  866.   BASE_EXT_DECL
  867.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  868.   register long d0 __asm("d0") = num;
  869.   __asm __volatile ("jsr a6@(-0x19e)"
  870.   : /* no output */
  871.   : "r" (a6), "r" (d0)
  872.   : "a0","a1","d0","d1", "memory");
  873. }
  874. static __inline void 
  875. FreeSpriteData (BASE_PAR_DECL struct ExtSprite *sp)
  876. {
  877.   BASE_EXT_DECL
  878.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  879.   register struct ExtSprite *a2 __asm("a2") = sp;
  880.   __asm __volatile ("jsr a6@(-0x408)"
  881.   : /* no output */
  882.   : "r" (a6), "r" (a2)
  883.   : "a0","a1","a2","d0","d1", "memory");
  884. }
  885. static __inline void 
  886. FreeVPortCopLists (BASE_PAR_DECL struct ViewPort *vp)
  887. {
  888.   BASE_EXT_DECL
  889.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  890.   register struct ViewPort *a0 __asm("a0") = vp;
  891.   __asm __volatile ("jsr a6@(-0x21c)"
  892.   : /* no output */
  893.   : "r" (a6), "r" (a0)
  894.   : "a0","a1","d0","d1", "memory");
  895. }
  896. static __inline ULONG 
  897. GetAPen (BASE_PAR_DECL struct RastPort *rp)
  898. {
  899.   BASE_EXT_DECL
  900.   register ULONG  _res  __asm("d0");
  901.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  902.   register struct RastPort *a0 __asm("a0") = rp;
  903.   __asm __volatile ("jsr a6@(-0x35a)"
  904.   : "=r" (_res)
  905.   : "r" (a6), "r" (a0)
  906.   : "a0","a1","d0","d1", "memory");
  907.   return _res;
  908. }
  909. static __inline ULONG 
  910. GetBPen (BASE_PAR_DECL struct RastPort *rp)
  911. {
  912.   BASE_EXT_DECL
  913.   register ULONG  _res  __asm("d0");
  914.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  915.   register struct RastPort *a0 __asm("a0") = rp;
  916.   __asm __volatile ("jsr a6@(-0x360)"
  917.   : "=r" (_res)
  918.   : "r" (a6), "r" (a0)
  919.   : "a0","a1","d0","d1", "memory");
  920.   return _res;
  921. }
  922. static __inline ULONG 
  923. GetBitMapAttr (BASE_PAR_DECL struct BitMap *bm,unsigned long attrnum)
  924. {
  925.   BASE_EXT_DECL
  926.   register ULONG  _res  __asm("d0");
  927.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  928.   register struct BitMap *a0 __asm("a0") = bm;
  929.   register unsigned long d1 __asm("d1") = attrnum;
  930.   __asm __volatile ("jsr a6@(-0x3c0)"
  931.   : "=r" (_res)
  932.   : "r" (a6), "r" (a0), "r" (d1)
  933.   : "a0","a1","d0","d1", "memory");
  934.   return _res;
  935. }
  936. static __inline struct ColorMap *
  937. GetColorMap (BASE_PAR_DECL long entries)
  938. {
  939.   BASE_EXT_DECL
  940.   register struct ColorMap * _res  __asm("d0");
  941.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  942.   register long d0 __asm("d0") = entries;
  943.   __asm __volatile ("jsr a6@(-0x23a)"
  944.   : "=r" (_res)
  945.   : "r" (a6), "r" (d0)
  946.   : "a0","a1","d0","d1", "memory");
  947.   return _res;
  948. }
  949. static __inline ULONG 
  950. GetDisplayInfoData (BASE_PAR_DECL DisplayInfoHandle handle,UBYTE *buf,unsigned long size,unsigned long tagID,unsigned long displayID)
  951. {
  952.   BASE_EXT_DECL
  953.   register ULONG  _res  __asm("d0");
  954.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  955.   register DisplayInfoHandle a0 __asm("a0") = handle;
  956.   register UBYTE *a1 __asm("a1") = buf;
  957.   register unsigned long d0 __asm("d0") = size;
  958.   register unsigned long d1 __asm("d1") = tagID;
  959.   register unsigned long d2 __asm("d2") = displayID;
  960.   __asm __volatile ("jsr a6@(-0x2f4)"
  961.   : "=r" (_res)
  962.   : "r" (a6), "r" (a0), "r" (a1), "r" (d0), "r" (d1), "r" (d2)
  963.   : "a0","a1","d0","d1","d2", "memory");
  964.   return _res;
  965. }
  966. static __inline ULONG 
  967. GetDrMd (BASE_PAR_DECL struct RastPort *rp)
  968. {
  969.   BASE_EXT_DECL
  970.   register ULONG  _res  __asm("d0");
  971.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  972.   register struct RastPort *a0 __asm("a0") = rp;
  973.   __asm __volatile ("jsr a6@(-0x366)"
  974.   : "=r" (_res)
  975.   : "r" (a6), "r" (a0)
  976.   : "a0","a1","d0","d1", "memory");
  977.   return _res;
  978. }
  979. static __inline LONG 
  980. GetExtSpriteA (BASE_PAR_DECL struct ExtSprite *ss,struct TagItem *tags)
  981. {
  982.   BASE_EXT_DECL
  983.   register LONG  _res  __asm("d0");
  984.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  985.   register struct ExtSprite *a2 __asm("a2") = ss;
  986.   register struct TagItem *a1 __asm("a1") = tags;
  987.   __asm __volatile ("jsr a6@(-0x3a2)"
  988.   : "=r" (_res)
  989.   : "r" (a6), "r" (a2), "r" (a1)
  990.   : "a0","a1","a2","d0","d1", "memory");
  991.   return _res;
  992. }
  993. static __inline BOOL 
  994. GetGBuffers (BASE_PAR_DECL struct AnimOb *anOb,struct RastPort *rp,long flag)
  995. {
  996.   BASE_EXT_DECL
  997.   register BOOL  _res  __asm("d0");
  998.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  999.   register struct AnimOb *a0 __asm("a0") = anOb;
  1000.   register struct RastPort *a1 __asm("a1") = rp;
  1001.   register long d0 __asm("d0") = flag;
  1002.   __asm __volatile ("jsr a6@(-0xa8)"
  1003.   : "=r" (_res)
  1004.   : "r" (a6), "r" (a0), "r" (a1), "r" (d0)
  1005.   : "a0","a1","d0","d1", "memory");
  1006.   return _res;
  1007. }
  1008. static __inline ULONG 
  1009. GetOutlinePen (BASE_PAR_DECL struct RastPort *rp)
  1010. {
  1011.   BASE_EXT_DECL
  1012.   register ULONG  _res  __asm("d0");
  1013.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1014.   register struct RastPort *a0 __asm("a0") = rp;
  1015.   __asm __volatile ("jsr a6@(-0x36c)"
  1016.   : "=r" (_res)
  1017.   : "r" (a6), "r" (a0)
  1018.   : "a0","a1","d0","d1", "memory");
  1019.   return _res;
  1020. }
  1021. static __inline void 
  1022. GetRGB32 (BASE_PAR_DECL struct ColorMap *cm,unsigned long firstcolor,unsigned long ncolors,ULONG *table)
  1023. {
  1024.   BASE_EXT_DECL
  1025.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1026.   register struct ColorMap *a0 __asm("a0") = cm;
  1027.   register unsigned long d0 __asm("d0") = firstcolor;
  1028.   register unsigned long d1 __asm("d1") = ncolors;
  1029.   register ULONG *a1 __asm("a1") = table;
  1030.   __asm __volatile ("jsr a6@(-0x384)"
  1031.   : /* no output */
  1032.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (a1)
  1033.   : "a0","a1","d0","d1", "memory");
  1034. }
  1035. static __inline ULONG 
  1036. GetRGB4 (BASE_PAR_DECL struct ColorMap *colorMap,long entry)
  1037. {
  1038.   BASE_EXT_DECL
  1039.   register ULONG  _res  __asm("d0");
  1040.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1041.   register struct ColorMap *a0 __asm("a0") = colorMap;
  1042.   register long d0 __asm("d0") = entry;
  1043.   __asm __volatile ("jsr a6@(-0x246)"
  1044.   : "=r" (_res)
  1045.   : "r" (a6), "r" (a0), "r" (d0)
  1046.   : "a0","a1","d0","d1", "memory");
  1047.   return _res;
  1048. }
  1049. static __inline void 
  1050. GetRPAttrsA (BASE_PAR_DECL struct RastPort *rp,struct TagItem *tags)
  1051. {
  1052.   BASE_EXT_DECL
  1053.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1054.   register struct RastPort *a0 __asm("a0") = rp;
  1055.   register struct TagItem *a1 __asm("a1") = tags;
  1056.   __asm __volatile ("jsr a6@(-0x414)"
  1057.   : /* no output */
  1058.   : "r" (a6), "r" (a0), "r" (a1)
  1059.   : "a0","a1","d0","d1", "memory");
  1060. }
  1061. static __inline WORD 
  1062. GetSprite (BASE_PAR_DECL struct SimpleSprite *sprite,long num)
  1063. {
  1064.   BASE_EXT_DECL
  1065.   register WORD  _res  __asm("d0");
  1066.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1067.   register struct SimpleSprite *a0 __asm("a0") = sprite;
  1068.   register long d0 __asm("d0") = num;
  1069.   __asm __volatile ("jsr a6@(-0x198)"
  1070.   : "=r" (_res)
  1071.   : "r" (a6), "r" (a0), "r" (d0)
  1072.   : "a0","a1","d0","d1", "memory");
  1073.   return _res;
  1074. }
  1075. static __inline LONG 
  1076. GetVPModeID (BASE_PAR_DECL struct ViewPort *vp)
  1077. {
  1078.   BASE_EXT_DECL
  1079.   register LONG  _res  __asm("d0");
  1080.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1081.   register struct ViewPort *a0 __asm("a0") = vp;
  1082.   __asm __volatile ("jsr a6@(-0x318)"
  1083.   : "=r" (_res)
  1084.   : "r" (a6), "r" (a0)
  1085.   : "a0","a1","d0","d1", "memory");
  1086.   return _res;
  1087. }
  1088. static __inline void 
  1089. GfxAssociate (BASE_PAR_DECL APTR associateNode,APTR gfxNodePtr)
  1090. {
  1091.   BASE_EXT_DECL
  1092.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1093.   register APTR a0 __asm("a0") = associateNode;
  1094.   register APTR a1 __asm("a1") = gfxNodePtr;
  1095.   __asm __volatile ("jsr a6@(-0x2a0)"
  1096.   : /* no output */
  1097.   : "r" (a6), "r" (a0), "r" (a1)
  1098.   : "a0","a1","d0","d1", "memory");
  1099. }
  1100. static __inline void 
  1101. GfxFree (BASE_PAR_DECL APTR gfxNodePtr)
  1102. {
  1103.   BASE_EXT_DECL
  1104.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1105.   register APTR a0 __asm("a0") = gfxNodePtr;
  1106.   __asm __volatile ("jsr a6@(-0x29a)"
  1107.   : /* no output */
  1108.   : "r" (a6), "r" (a0)
  1109.   : "a0","a1","d0","d1", "memory");
  1110. }
  1111. static __inline APTR 
  1112. GfxLookUp (BASE_PAR_DECL APTR associateNode)
  1113. {
  1114.   BASE_EXT_DECL
  1115.   register APTR  _res  __asm("d0");
  1116.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1117.   register APTR a0 __asm("a0") = associateNode;
  1118.   __asm __volatile ("jsr a6@(-0x2be)"
  1119.   : "=r" (_res)
  1120.   : "r" (a6), "r" (a0)
  1121.   : "a0","a1","d0","d1", "memory");
  1122.   return _res;
  1123. }
  1124. static __inline APTR 
  1125. GfxNew (BASE_PAR_DECL unsigned long gfxNodeType)
  1126. {
  1127.   BASE_EXT_DECL
  1128.   register APTR  _res  __asm("d0");
  1129.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1130.   register unsigned long d0 __asm("d0") = gfxNodeType;
  1131.   __asm __volatile ("jsr a6@(-0x294)"
  1132.   : "=r" (_res)
  1133.   : "r" (a6), "r" (d0)
  1134.   : "a0","a1","d0","d1", "memory");
  1135.   return _res;
  1136. }
  1137. static __inline void 
  1138. InitArea (BASE_PAR_DECL struct AreaInfo *areaInfo,APTR vectorBuffer,long maxVectors)
  1139. {
  1140.   BASE_EXT_DECL
  1141.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1142.   register struct AreaInfo *a0 __asm("a0") = areaInfo;
  1143.   register APTR a1 __asm("a1") = vectorBuffer;
  1144.   register long d0 __asm("d0") = maxVectors;
  1145.   __asm __volatile ("jsr a6@(-0x11a)"
  1146.   : /* no output */
  1147.   : "r" (a6), "r" (a0), "r" (a1), "r" (d0)
  1148.   : "a0","a1","d0","d1", "memory");
  1149. }
  1150. static __inline void 
  1151. InitBitMap (BASE_PAR_DECL struct BitMap *bitMap,long depth,long width,long height)
  1152. {
  1153.   BASE_EXT_DECL
  1154.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1155.   register struct BitMap *a0 __asm("a0") = bitMap;
  1156.   register long d0 __asm("d0") = depth;
  1157.   register long d1 __asm("d1") = width;
  1158.   register long d2 __asm("d2") = height;
  1159.   __asm __volatile ("jsr a6@(-0x186)"
  1160.   : /* no output */
  1161.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2)
  1162.   : "a0","a1","d0","d1","d2", "memory");
  1163. }
  1164. static __inline void 
  1165. InitGMasks (BASE_PAR_DECL struct AnimOb *anOb)
  1166. {
  1167.   BASE_EXT_DECL
  1168.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1169.   register struct AnimOb *a0 __asm("a0") = anOb;
  1170.   __asm __volatile ("jsr a6@(-0xae)"
  1171.   : /* no output */
  1172.   : "r" (a6), "r" (a0)
  1173.   : "a0","a1","d0","d1", "memory");
  1174. }
  1175. static __inline void 
  1176. InitGels (BASE_PAR_DECL struct VSprite *head,struct VSprite *tail,struct GelsInfo *gelsInfo)
  1177. {
  1178.   BASE_EXT_DECL
  1179.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1180.   register struct VSprite *a0 __asm("a0") = head;
  1181.   register struct VSprite *a1 __asm("a1") = tail;
  1182.   register struct GelsInfo *a2 __asm("a2") = gelsInfo;
  1183.   __asm __volatile ("jsr a6@(-0x78)"
  1184.   : /* no output */
  1185.   : "r" (a6), "r" (a0), "r" (a1), "r" (a2)
  1186.   : "a0","a1","a2","d0","d1", "memory");
  1187. }
  1188. static __inline void 
  1189. InitMasks (BASE_PAR_DECL struct VSprite *vSprite)
  1190. {
  1191.   BASE_EXT_DECL
  1192.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1193.   register struct VSprite *a0 __asm("a0") = vSprite;
  1194.   __asm __volatile ("jsr a6@(-0x7e)"
  1195.   : /* no output */
  1196.   : "r" (a6), "r" (a0)
  1197.   : "a0","a1","d0","d1", "memory");
  1198. }
  1199. static __inline void 
  1200. InitRastPort (BASE_PAR_DECL struct RastPort *rp)
  1201. {
  1202.   BASE_EXT_DECL
  1203.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1204.   register struct RastPort *a1 __asm("a1") = rp;
  1205.   __asm __volatile ("jsr a6@(-0xc6)"
  1206.   : /* no output */
  1207.   : "r" (a6), "r" (a1)
  1208.   : "a0","a1","d0","d1", "memory");
  1209. }
  1210. static __inline struct TmpRas *
  1211. InitTmpRas (BASE_PAR_DECL struct TmpRas *tmpRas,PLANEPTR buffer,long size)
  1212. {
  1213.   BASE_EXT_DECL
  1214.   register struct TmpRas * _res  __asm("d0");
  1215.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1216.   register struct TmpRas *a0 __asm("a0") = tmpRas;
  1217.   register PLANEPTR a1 __asm("a1") = buffer;
  1218.   register long d0 __asm("d0") = size;
  1219.   __asm __volatile ("jsr a6@(-0x1d4)"
  1220.   : "=r" (_res)
  1221.   : "r" (a6), "r" (a0), "r" (a1), "r" (d0)
  1222.   : "a0","a1","d0","d1", "memory");
  1223.   return _res;
  1224. }
  1225. static __inline void 
  1226. InitVPort (BASE_PAR_DECL struct ViewPort *vp)
  1227. {
  1228.   BASE_EXT_DECL
  1229.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1230.   register struct ViewPort *a0 __asm("a0") = vp;
  1231.   __asm __volatile ("jsr a6@(-0xcc)"
  1232.   : /* no output */
  1233.   : "r" (a6), "r" (a0)
  1234.   : "a0","a1","d0","d1", "memory");
  1235. }
  1236. static __inline void 
  1237. InitView (BASE_PAR_DECL struct View *view)
  1238. {
  1239.   BASE_EXT_DECL
  1240.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1241.   register struct View *a1 __asm("a1") = view;
  1242.   __asm __volatile ("jsr a6@(-0x168)"
  1243.   : /* no output */
  1244.   : "r" (a6), "r" (a1)
  1245.   : "a0","a1","d0","d1", "memory");
  1246. }
  1247. static __inline void 
  1248. LoadRGB32 (BASE_PAR_DECL struct ViewPort *vp,ULONG *table)
  1249. {
  1250.   BASE_EXT_DECL
  1251.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1252.   register struct ViewPort *a0 __asm("a0") = vp;
  1253.   register ULONG *a1 __asm("a1") = table;
  1254.   __asm __volatile ("jsr a6@(-0x372)"
  1255.   : /* no output */
  1256.   : "r" (a6), "r" (a0), "r" (a1)
  1257.   : "a0","a1","d0","d1", "memory");
  1258. }
  1259. static __inline void 
  1260. LoadRGB4 (BASE_PAR_DECL struct ViewPort *vp,UWORD *colors,long count)
  1261. {
  1262.   BASE_EXT_DECL
  1263.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1264.   register struct ViewPort *a0 __asm("a0") = vp;
  1265.   register UWORD *a1 __asm("a1") = colors;
  1266.   register long d0 __asm("d0") = count;
  1267.   __asm __volatile ("jsr a6@(-0xc0)"
  1268.   : /* no output */
  1269.   : "r" (a6), "r" (a0), "r" (a1), "r" (d0)
  1270.   : "a0","a1","d0","d1", "memory");
  1271. }
  1272. static __inline void 
  1273. LoadView (BASE_PAR_DECL struct View *view)
  1274. {
  1275.   BASE_EXT_DECL
  1276.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1277.   register struct View *a1 __asm("a1") = view;
  1278.   __asm __volatile ("jsr a6@(-0xde)"
  1279.   : /* no output */
  1280.   : "r" (a6), "r" (a1)
  1281.   : "a0","a1","d0","d1", "memory");
  1282. }
  1283. static __inline void 
  1284. LockLayerRom (BASE_PAR_DECL struct Layer *layer)
  1285. {
  1286.   BASE_EXT_DECL
  1287.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1288.   register struct Layer *a5 __asm("a5") = layer;
  1289.   __asm __volatile ("jsr a6@(-0x1b0)"
  1290.   : /* no output */
  1291.   : "r" (a6), "r" (a5)
  1292.   : "a0","a1","a5","d0","d1", "memory");
  1293. }
  1294. static __inline ULONG 
  1295. MakeVPort (BASE_PAR_DECL struct View *view,struct ViewPort *vp)
  1296. {
  1297.   BASE_EXT_DECL
  1298.   register ULONG  _res  __asm("d0");
  1299.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1300.   register struct View *a0 __asm("a0") = view;
  1301.   register struct ViewPort *a1 __asm("a1") = vp;
  1302.   __asm __volatile ("jsr a6@(-0xd8)"
  1303.   : "=r" (_res)
  1304.   : "r" (a6), "r" (a0), "r" (a1)
  1305.   : "a0","a1","d0","d1", "memory");
  1306.   return _res;
  1307. }
  1308. static __inline LONG 
  1309. ModeNotAvailable (BASE_PAR_DECL unsigned long modeID)
  1310. {
  1311.   BASE_EXT_DECL
  1312.   register LONG  _res  __asm("d0");
  1313.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1314.   register unsigned long d0 __asm("d0") = modeID;
  1315.   __asm __volatile ("jsr a6@(-0x31e)"
  1316.   : "=r" (_res)
  1317.   : "r" (a6), "r" (d0)
  1318.   : "a0","a1","d0","d1", "memory");
  1319.   return _res;
  1320. }
  1321. static __inline void 
  1322. Move (BASE_PAR_DECL struct RastPort *rp,long x,long y)
  1323. {
  1324.   BASE_EXT_DECL
  1325.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1326.   register struct RastPort *a1 __asm("a1") = rp;
  1327.   register long d0 __asm("d0") = x;
  1328.   register long d1 __asm("d1") = y;
  1329.   __asm __volatile ("jsr a6@(-0xf0)"
  1330.   : /* no output */
  1331.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  1332.   : "a0","a1","d0","d1", "memory");
  1333. }
  1334. static __inline void 
  1335. MoveSprite (BASE_PAR_DECL struct ViewPort *vp,struct SimpleSprite *sprite,long x,long y)
  1336. {
  1337.   BASE_EXT_DECL
  1338.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1339.   register struct ViewPort *a0 __asm("a0") = vp;
  1340.   register struct SimpleSprite *a1 __asm("a1") = sprite;
  1341.   register long d0 __asm("d0") = x;
  1342.   register long d1 __asm("d1") = y;
  1343.   __asm __volatile ("jsr a6@(-0x1aa)"
  1344.   : /* no output */
  1345.   : "r" (a6), "r" (a0), "r" (a1), "r" (d0), "r" (d1)
  1346.   : "a0","a1","d0","d1", "memory");
  1347. }
  1348. static __inline ULONG 
  1349. MrgCop (BASE_PAR_DECL struct View *view)
  1350. {
  1351.   BASE_EXT_DECL
  1352.   register ULONG  _res  __asm("d0");
  1353.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1354.   register struct View *a1 __asm("a1") = view;
  1355.   __asm __volatile ("jsr a6@(-0xd2)"
  1356.   : "=r" (_res)
  1357.   : "r" (a6), "r" (a1)
  1358.   : "a0","a1","d0","d1", "memory");
  1359.   return _res;
  1360. }
  1361. static __inline struct Region *
  1362. NewRegion (BASE_PAR_DECL0)
  1363. {
  1364.   BASE_EXT_DECL
  1365.   register struct Region * _res  __asm("d0");
  1366.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1367.   __asm __volatile ("jsr a6@(-0x204)"
  1368.   : "=r" (_res)
  1369.   : "r" (a6)
  1370.   : "a0","a1","d0","d1", "memory");
  1371.   return _res;
  1372. }
  1373. static __inline ULONG 
  1374. NextDisplayInfo (BASE_PAR_DECL unsigned long displayID)
  1375. {
  1376.   BASE_EXT_DECL
  1377.   register ULONG  _res  __asm("d0");
  1378.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1379.   register unsigned long d0 __asm("d0") = displayID;
  1380.   __asm __volatile ("jsr a6@(-0x2dc)"
  1381.   : "=r" (_res)
  1382.   : "r" (a6), "r" (d0)
  1383.   : "a0","a1","d0","d1", "memory");
  1384.   return _res;
  1385. }
  1386. static __inline LONG 
  1387. ObtainBestPenA (BASE_PAR_DECL struct ColorMap *cm,unsigned long r,unsigned long g,unsigned long b,struct TagItem *tags)
  1388. {
  1389.   BASE_EXT_DECL
  1390.   register LONG  _res  __asm("d0");
  1391.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1392.   register struct ColorMap *a0 __asm("a0") = cm;
  1393.   register unsigned long d1 __asm("d1") = r;
  1394.   register unsigned long d2 __asm("d2") = g;
  1395.   register unsigned long d3 __asm("d3") = b;
  1396.   register struct TagItem *a1 __asm("a1") = tags;
  1397.   __asm __volatile ("jsr a6@(-0x348)"
  1398.   : "=r" (_res)
  1399.   : "r" (a6), "r" (a0), "r" (d1), "r" (d2), "r" (d3), "r" (a1)
  1400.   : "a0","a1","d0","d1","d2","d3", "memory");
  1401.   return _res;
  1402. }
  1403. static __inline ULONG 
  1404. ObtainPen (BASE_PAR_DECL struct ColorMap *cm,unsigned long n,unsigned long r,unsigned long g,unsigned long b,long f)
  1405. {
  1406.   BASE_EXT_DECL
  1407.   register ULONG  _res  __asm("d0");
  1408.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1409.   register struct ColorMap *a0 __asm("a0") = cm;
  1410.   register unsigned long d0 __asm("d0") = n;
  1411.   register unsigned long d1 __asm("d1") = r;
  1412.   register unsigned long d2 __asm("d2") = g;
  1413.   register unsigned long d3 __asm("d3") = b;
  1414.   register long d4 __asm("d4") = f;
  1415.   __asm __volatile ("jsr a6@(-0x3ba)"
  1416.   : "=r" (_res)
  1417.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3), "r" (d4)
  1418.   : "a0","a1","d0","d1","d2","d3","d4", "memory");
  1419.   return _res;
  1420. }
  1421. static __inline struct TextFont *
  1422. OpenFont (BASE_PAR_DECL struct TextAttr *textAttr)
  1423. {
  1424.   BASE_EXT_DECL
  1425.   register struct TextFont * _res  __asm("d0");
  1426.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1427.   register struct TextAttr *a0 __asm("a0") = textAttr;
  1428.   __asm __volatile ("jsr a6@(-0x48)"
  1429.   : "=r" (_res)
  1430.   : "r" (a6), "r" (a0)
  1431.   : "a0","a1","d0","d1", "memory");
  1432.   return _res;
  1433. }
  1434. static __inline struct MonitorSpec *
  1435. OpenMonitor (BASE_PAR_DECL STRPTR monitorName,unsigned long displayID)
  1436. {
  1437.   BASE_EXT_DECL
  1438.   register struct MonitorSpec * _res  __asm("d0");
  1439.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1440.   register STRPTR a1 __asm("a1") = monitorName;
  1441.   register unsigned long d0 __asm("d0") = displayID;
  1442.   __asm __volatile ("jsr a6@(-0x2ca)"
  1443.   : "=r" (_res)
  1444.   : "r" (a6), "r" (a1), "r" (d0)
  1445.   : "a0","a1","d0","d1", "memory");
  1446.   return _res;
  1447. }
  1448. static __inline BOOL 
  1449. OrRectRegion (BASE_PAR_DECL struct Region *region,struct Rectangle *rectangle)
  1450. {
  1451.   BASE_EXT_DECL
  1452.   register BOOL  _res  __asm("d0");
  1453.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1454.   register struct Region *a0 __asm("a0") = region;
  1455.   register struct Rectangle *a1 __asm("a1") = rectangle;
  1456.   __asm __volatile ("jsr a6@(-0x1fe)"
  1457.   : "=r" (_res)
  1458.   : "r" (a6), "r" (a0), "r" (a1)
  1459.   : "a0","a1","d0","d1", "memory");
  1460.   return _res;
  1461. }
  1462. static __inline BOOL 
  1463. OrRegionRegion (BASE_PAR_DECL struct Region *srcRegion,struct Region *destRegion)
  1464. {
  1465.   BASE_EXT_DECL
  1466.   register BOOL  _res  __asm("d0");
  1467.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1468.   register struct Region *a0 __asm("a0") = srcRegion;
  1469.   register struct Region *a1 __asm("a1") = destRegion;
  1470.   __asm __volatile ("jsr a6@(-0x264)"
  1471.   : "=r" (_res)
  1472.   : "r" (a6), "r" (a0), "r" (a1)
  1473.   : "a0","a1","d0","d1", "memory");
  1474.   return _res;
  1475. }
  1476. static __inline void 
  1477. OwnBlitter (BASE_PAR_DECL0)
  1478. {
  1479.   BASE_EXT_DECL
  1480.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1481.   __asm __volatile ("jsr a6@(-0x1c8)"
  1482.   : /* no output */
  1483.   : "r" (a6)
  1484.   : "a0","a1","d0","d1", "memory");
  1485. }
  1486. static __inline void 
  1487. PolyDraw (BASE_PAR_DECL struct RastPort *rp,long count,WORD *polyTable)
  1488. {
  1489.   BASE_EXT_DECL
  1490.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1491.   register struct RastPort *a1 __asm("a1") = rp;
  1492.   register long d0 __asm("d0") = count;
  1493.   register WORD *a0 __asm("a0") = polyTable;
  1494.   __asm __volatile ("jsr a6@(-0x150)"
  1495.   : /* no output */
  1496.   : "r" (a6), "r" (a1), "r" (d0), "r" (a0)
  1497.   : "a0","a1","d0","d1", "memory");
  1498. }
  1499. static __inline void 
  1500. QBSBlit (BASE_PAR_DECL struct bltnode *blit)
  1501. {
  1502.   BASE_EXT_DECL
  1503.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1504.   register struct bltnode *a1 __asm("a1") = blit;
  1505.   __asm __volatile ("jsr a6@(-0x126)"
  1506.   : /* no output */
  1507.   : "r" (a6), "r" (a1)
  1508.   : "a0","a1","d0","d1", "memory");
  1509. }
  1510. static __inline void 
  1511. QBlit (BASE_PAR_DECL struct bltnode *blit)
  1512. {
  1513.   BASE_EXT_DECL
  1514.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1515.   register struct bltnode *a1 __asm("a1") = blit;
  1516.   __asm __volatile ("jsr a6@(-0x114)"
  1517.   : /* no output */
  1518.   : "r" (a6), "r" (a1)
  1519.   : "a0","a1","d0","d1", "memory");
  1520. }
  1521. static __inline ULONG 
  1522. ReadPixel (BASE_PAR_DECL struct RastPort *rp,long x,long y)
  1523. {
  1524.   BASE_EXT_DECL
  1525.   register ULONG  _res  __asm("d0");
  1526.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1527.   register struct RastPort *a1 __asm("a1") = rp;
  1528.   register long d0 __asm("d0") = x;
  1529.   register long d1 __asm("d1") = y;
  1530.   __asm __volatile ("jsr a6@(-0x13e)"
  1531.   : "=r" (_res)
  1532.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  1533.   : "a0","a1","d0","d1", "memory");
  1534.   return _res;
  1535. }
  1536. static __inline LONG 
  1537. ReadPixelArray8 (BASE_PAR_DECL struct RastPort *rp,unsigned long xstart,unsigned long ystart,unsigned long xstop,unsigned long ystop,UBYTE *array,struct RastPort *temprp)
  1538. {
  1539.   BASE_EXT_DECL
  1540.   register LONG  _res  __asm("d0");
  1541.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1542.   register struct RastPort *a0 __asm("a0") = rp;
  1543.   register unsigned long d0 __asm("d0") = xstart;
  1544.   register unsigned long d1 __asm("d1") = ystart;
  1545.   register unsigned long d2 __asm("d2") = xstop;
  1546.   register unsigned long d3 __asm("d3") = ystop;
  1547.   register UBYTE *a2 __asm("a2") = array;
  1548.   register struct RastPort *a1 __asm("a1") = temprp;
  1549.   __asm __volatile ("jsr a6@(-0x30c)"
  1550.   : "=r" (_res)
  1551.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3), "r" (a2), "r" (a1)
  1552.   : "a0","a1","a2","d0","d1","d2","d3", "memory");
  1553.   return _res;
  1554. }
  1555. static __inline LONG 
  1556. ReadPixelLine8 (BASE_PAR_DECL struct RastPort *rp,unsigned long xstart,unsigned long ystart,unsigned long width,UBYTE *array,struct RastPort *tempRP)
  1557. {
  1558.   BASE_EXT_DECL
  1559.   register LONG  _res  __asm("d0");
  1560.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1561.   register struct RastPort *a0 __asm("a0") = rp;
  1562.   register unsigned long d0 __asm("d0") = xstart;
  1563.   register unsigned long d1 __asm("d1") = ystart;
  1564.   register unsigned long d2 __asm("d2") = width;
  1565.   register UBYTE *a2 __asm("a2") = array;
  1566.   register struct RastPort *a1 __asm("a1") = tempRP;
  1567.   __asm __volatile ("jsr a6@(-0x300)"
  1568.   : "=r" (_res)
  1569.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (a2), "r" (a1)
  1570.   : "a0","a1","a2","d0","d1","d2", "memory");
  1571.   return _res;
  1572. }
  1573. static __inline void 
  1574. RectFill (BASE_PAR_DECL struct RastPort *rp,long xMin,long yMin,long xMax,long yMax)
  1575. {
  1576.   BASE_EXT_DECL
  1577.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1578.   register struct RastPort *a1 __asm("a1") = rp;
  1579.   register long d0 __asm("d0") = xMin;
  1580.   register long d1 __asm("d1") = yMin;
  1581.   register long d2 __asm("d2") = xMax;
  1582.   register long d3 __asm("d3") = yMax;
  1583.   __asm __volatile ("jsr a6@(-0x132)"
  1584.   : /* no output */
  1585.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1), "r" (d2), "r" (d3)
  1586.   : "a0","a1","d0","d1","d2","d3", "memory");
  1587. }
  1588. static __inline void 
  1589. ReleasePen (BASE_PAR_DECL struct ColorMap *cm,unsigned long n)
  1590. {
  1591.   BASE_EXT_DECL
  1592.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1593.   register struct ColorMap *a0 __asm("a0") = cm;
  1594.   register unsigned long d0 __asm("d0") = n;
  1595.   __asm __volatile ("jsr a6@(-0x3b4)"
  1596.   : /* no output */
  1597.   : "r" (a6), "r" (a0), "r" (d0)
  1598.   : "a0","a1","d0","d1", "memory");
  1599. }
  1600. static __inline void 
  1601. RemFont (BASE_PAR_DECL struct TextFont *textFont)
  1602. {
  1603.   BASE_EXT_DECL
  1604.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1605.   register struct TextFont *a1 __asm("a1") = textFont;
  1606.   __asm __volatile ("jsr a6@(-0x1e6)"
  1607.   : /* no output */
  1608.   : "r" (a6), "r" (a1)
  1609.   : "a0","a1","d0","d1", "memory");
  1610. }
  1611. static __inline void 
  1612. RemIBob (BASE_PAR_DECL struct Bob *bob,struct RastPort *rp,struct ViewPort *vp)
  1613. {
  1614.   BASE_EXT_DECL
  1615.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1616.   register struct Bob *a0 __asm("a0") = bob;
  1617.   register struct RastPort *a1 __asm("a1") = rp;
  1618.   register struct ViewPort *a2 __asm("a2") = vp;
  1619.   __asm __volatile ("jsr a6@(-0x84)"
  1620.   : /* no output */
  1621.   : "r" (a6), "r" (a0), "r" (a1), "r" (a2)
  1622.   : "a0","a1","a2","d0","d1", "memory");
  1623. }
  1624. static __inline void 
  1625. RemVSprite (BASE_PAR_DECL struct VSprite *vSprite)
  1626. {
  1627.   BASE_EXT_DECL
  1628.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1629.   register struct VSprite *a0 __asm("a0") = vSprite;
  1630.   __asm __volatile ("jsr a6@(-0x8a)"
  1631.   : /* no output */
  1632.   : "r" (a6), "r" (a0)
  1633.   : "a0","a1","d0","d1", "memory");
  1634. }
  1635. static __inline UWORD 
  1636. ScalerDiv (BASE_PAR_DECL unsigned long factor,unsigned long numerator,unsigned long denominator)
  1637. {
  1638.   BASE_EXT_DECL
  1639.   register UWORD  _res  __asm("d0");
  1640.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1641.   register unsigned long d0 __asm("d0") = factor;
  1642.   register unsigned long d1 __asm("d1") = numerator;
  1643.   register unsigned long d2 __asm("d2") = denominator;
  1644.   __asm __volatile ("jsr a6@(-0x2ac)"
  1645.   : "=r" (_res)
  1646.   : "r" (a6), "r" (d0), "r" (d1), "r" (d2)
  1647.   : "a0","a1","d0","d1","d2", "memory");
  1648.   return _res;
  1649. }
  1650. static __inline void 
  1651. ScrollRaster (BASE_PAR_DECL struct RastPort *rp,long dx,long dy,long xMin,long yMin,long xMax,long yMax)
  1652. {
  1653.   BASE_EXT_DECL
  1654.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1655.   register struct RastPort *a1 __asm("a1") = rp;
  1656.   register long d0 __asm("d0") = dx;
  1657.   register long d1 __asm("d1") = dy;
  1658.   register long d2 __asm("d2") = xMin;
  1659.   register long d3 __asm("d3") = yMin;
  1660.   register long d4 __asm("d4") = xMax;
  1661.   register long d5 __asm("d5") = yMax;
  1662.   __asm __volatile ("jsr a6@(-0x18c)"
  1663.   : /* no output */
  1664.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1), "r" (d2), "r" (d3), "r" (d4), "r" (d5)
  1665.   : "a0","a1","d0","d1","d2","d3","d4","d5", "memory");
  1666. }
  1667. static __inline void 
  1668. ScrollRasterBF (BASE_PAR_DECL struct RastPort *rp,long dx,long dy,long xMin,long yMin,long xMax,long yMax)
  1669. {
  1670.   BASE_EXT_DECL
  1671.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1672.   register struct RastPort *a1 __asm("a1") = rp;
  1673.   register long d0 __asm("d0") = dx;
  1674.   register long d1 __asm("d1") = dy;
  1675.   register long d2 __asm("d2") = xMin;
  1676.   register long d3 __asm("d3") = yMin;
  1677.   register long d4 __asm("d4") = xMax;
  1678.   register long d5 __asm("d5") = yMax;
  1679.   __asm __volatile ("jsr a6@(-0x3ea)"
  1680.   : /* no output */
  1681.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1), "r" (d2), "r" (d3), "r" (d4), "r" (d5)
  1682.   : "a0","a1","d0","d1","d2","d3","d4","d5", "memory");
  1683. }
  1684. static __inline void 
  1685. ScrollVPort (BASE_PAR_DECL struct ViewPort *vp)
  1686. {
  1687.   BASE_EXT_DECL
  1688.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1689.   register struct ViewPort *a0 __asm("a0") = vp;
  1690.   __asm __volatile ("jsr a6@(-0x24c)"
  1691.   : /* no output */
  1692.   : "r" (a6), "r" (a0)
  1693.   : "a0","a1","d0","d1", "memory");
  1694. }
  1695. static __inline void 
  1696. SetABPenDrMd (BASE_PAR_DECL struct RastPort *rp,unsigned long apen,unsigned long bpen,unsigned long drawmode)
  1697. {
  1698.   BASE_EXT_DECL
  1699.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1700.   register struct RastPort *a1 __asm("a1") = rp;
  1701.   register unsigned long d0 __asm("d0") = apen;
  1702.   register unsigned long d1 __asm("d1") = bpen;
  1703.   register unsigned long d2 __asm("d2") = drawmode;
  1704.   __asm __volatile ("jsr a6@(-0x37e)"
  1705.   : /* no output */
  1706.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1), "r" (d2)
  1707.   : "a0","a1","d0","d1","d2", "memory");
  1708. }
  1709. static __inline void 
  1710. SetAPen (BASE_PAR_DECL struct RastPort *rp,unsigned long pen)
  1711. {
  1712.   BASE_EXT_DECL
  1713.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1714.   register struct RastPort *a1 __asm("a1") = rp;
  1715.   register unsigned long d0 __asm("d0") = pen;
  1716.   __asm __volatile ("jsr a6@(-0x156)"
  1717.   : /* no output */
  1718.   : "r" (a6), "r" (a1), "r" (d0)
  1719.   : "a0","a1","d0","d1", "memory");
  1720. }
  1721. static __inline void 
  1722. SetBPen (BASE_PAR_DECL struct RastPort *rp,unsigned long pen)
  1723. {
  1724.   BASE_EXT_DECL
  1725.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1726.   register struct RastPort *a1 __asm("a1") = rp;
  1727.   register unsigned long d0 __asm("d0") = pen;
  1728.   __asm __volatile ("jsr a6@(-0x15c)"
  1729.   : /* no output */
  1730.   : "r" (a6), "r" (a1), "r" (d0)
  1731.   : "a0","a1","d0","d1", "memory");
  1732. }
  1733. static __inline ULONG 
  1734. SetChipRev (BASE_PAR_DECL unsigned long want)
  1735. {
  1736.   BASE_EXT_DECL
  1737.   register ULONG  _res  __asm("d0");
  1738.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1739.   register unsigned long d0 __asm("d0") = want;
  1740.   __asm __volatile ("jsr a6@(-0x378)"
  1741.   : "=r" (_res)
  1742.   : "r" (a6), "r" (d0)
  1743.   : "a0","a1","d0","d1", "memory");
  1744.   return _res;
  1745. }
  1746. static __inline void 
  1747. SetCollision (BASE_PAR_DECL unsigned long num,void (*routine)(struct VSprite *routine,gelsInfo),struct GelsInfo *)
  1748. {
  1749.   BASE_EXT_DECL
  1750.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1751.   register unsigned long d0 __asm("d0") = num;
  1752.   register void (*a0)(struct VSprite *routine __asm("a0") = routine;
  1753.   register gelsInfo) __asm("a1") = gelsInfo;
  1754.   register struct GelsInfo * __asm("") = ;
  1755.   __asm __volatile ("jsr a6@(-0x90)"
  1756.   : /* no output */
  1757.   : "r" (a6), "r" (d0), "r" (a0), "r" (a1), "r" ()
  1758.   : "a0","a1","d0","d1", "memory");
  1759. }
  1760. static __inline void 
  1761. SetDrMd (BASE_PAR_DECL struct RastPort *rp,unsigned long drawMode)
  1762. {
  1763.   BASE_EXT_DECL
  1764.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1765.   register struct RastPort *a1 __asm("a1") = rp;
  1766.   register unsigned long d0 __asm("d0") = drawMode;
  1767.   __asm __volatile ("jsr a6@(-0x162)"
  1768.   : /* no output */
  1769.   : "r" (a6), "r" (a1), "r" (d0)
  1770.   : "a0","a1","d0","d1", "memory");
  1771. }
  1772. static __inline LONG 
  1773. SetFont (BASE_PAR_DECL struct RastPort *rp,struct TextFont *textFont)
  1774. {
  1775.   BASE_EXT_DECL
  1776.   register LONG  _res  __asm("d0");
  1777.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1778.   register struct RastPort *a1 __asm("a1") = rp;
  1779.   register struct TextFont *a0 __asm("a0") = textFont;
  1780.   __asm __volatile ("jsr a6@(-0x42)"
  1781.   : "=r" (_res)
  1782.   : "r" (a6), "r" (a1), "r" (a0)
  1783.   : "a0","a1","d0","d1", "memory");
  1784.   return _res;
  1785. }
  1786. static __inline void 
  1787. SetMaxPen (BASE_PAR_DECL struct RastPort *rp,unsigned long maxpen)
  1788. {
  1789.   BASE_EXT_DECL
  1790.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1791.   register struct RastPort *a0 __asm("a0") = rp;
  1792.   register unsigned long d0 __asm("d0") = maxpen;
  1793.   __asm __volatile ("jsr a6@(-0x3de)"
  1794.   : /* no output */
  1795.   : "r" (a6), "r" (a0), "r" (d0)
  1796.   : "a0","a1","d0","d1", "memory");
  1797. }
  1798. static __inline ULONG 
  1799. SetOutlinePen (BASE_PAR_DECL struct RastPort *rp,unsigned long pen)
  1800. {
  1801.   BASE_EXT_DECL
  1802.   register ULONG  _res  __asm("d0");
  1803.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1804.   register struct RastPort *a0 __asm("a0") = rp;
  1805.   register unsigned long d0 __asm("d0") = pen;
  1806.   __asm __volatile ("jsr a6@(-0x3d2)"
  1807.   : "=r" (_res)
  1808.   : "r" (a6), "r" (a0), "r" (d0)
  1809.   : "a0","a1","d0","d1", "memory");
  1810.   return _res;
  1811. }
  1812. static __inline void 
  1813. SetRGB32 (BASE_PAR_DECL struct ViewPort *vp,unsigned long n,unsigned long r,unsigned long g,unsigned long b)
  1814. {
  1815.   BASE_EXT_DECL
  1816.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1817.   register struct ViewPort *a0 __asm("a0") = vp;
  1818.   register unsigned long d0 __asm("d0") = n;
  1819.   register unsigned long d1 __asm("d1") = r;
  1820.   register unsigned long d2 __asm("d2") = g;
  1821.   register unsigned long d3 __asm("d3") = b;
  1822.   __asm __volatile ("jsr a6@(-0x354)"
  1823.   : /* no output */
  1824.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3)
  1825.   : "a0","a1","d0","d1","d2","d3", "memory");
  1826. }
  1827. static __inline void 
  1828. SetRGB32CM (BASE_PAR_DECL struct ColorMap *cm,unsigned long n,unsigned long r,unsigned long g,unsigned long b)
  1829. {
  1830.   BASE_EXT_DECL
  1831.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1832.   register struct ColorMap *a0 __asm("a0") = cm;
  1833.   register unsigned long d0 __asm("d0") = n;
  1834.   register unsigned long d1 __asm("d1") = r;
  1835.   register unsigned long d2 __asm("d2") = g;
  1836.   register unsigned long d3 __asm("d3") = b;
  1837.   __asm __volatile ("jsr a6@(-0x3e4)"
  1838.   : /* no output */
  1839.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3)
  1840.   : "a0","a1","d0","d1","d2","d3", "memory");
  1841. }
  1842. static __inline void 
  1843. SetRGB4 (BASE_PAR_DECL struct ViewPort *vp,long index,unsigned long red,unsigned long green,unsigned long blue)
  1844. {
  1845.   BASE_EXT_DECL
  1846.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1847.   register struct ViewPort *a0 __asm("a0") = vp;
  1848.   register long d0 __asm("d0") = index;
  1849.   register unsigned long d1 __asm("d1") = red;
  1850.   register unsigned long d2 __asm("d2") = green;
  1851.   register unsigned long d3 __asm("d3") = blue;
  1852.   __asm __volatile ("jsr a6@(-0x120)"
  1853.   : /* no output */
  1854.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3)
  1855.   : "a0","a1","d0","d1","d2","d3", "memory");
  1856. }
  1857. static __inline void 
  1858. SetRGB4CM (BASE_PAR_DECL struct ColorMap *colorMap,long index,unsigned long red,unsigned long green,unsigned long blue)
  1859. {
  1860.   BASE_EXT_DECL
  1861.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1862.   register struct ColorMap *a0 __asm("a0") = colorMap;
  1863.   register long d0 __asm("d0") = index;
  1864.   register unsigned long d1 __asm("d1") = red;
  1865.   register unsigned long d2 __asm("d2") = green;
  1866.   register unsigned long d3 __asm("d3") = blue;
  1867.   __asm __volatile ("jsr a6@(-0x276)"
  1868.   : /* no output */
  1869.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3)
  1870.   : "a0","a1","d0","d1","d2","d3", "memory");
  1871. }
  1872. static __inline void 
  1873. SetRPAttrsA (BASE_PAR_DECL struct RastPort *rp,struct TagItem *tags)
  1874. {
  1875.   BASE_EXT_DECL
  1876.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1877.   register struct RastPort *a0 __asm("a0") = rp;
  1878.   register struct TagItem *a1 __asm("a1") = tags;
  1879.   __asm __volatile ("jsr a6@(-0x40e)"
  1880.   : /* no output */
  1881.   : "r" (a6), "r" (a0), "r" (a1)
  1882.   : "a0","a1","d0","d1", "memory");
  1883. }
  1884. static __inline void 
  1885. SetRast (BASE_PAR_DECL struct RastPort *rp,unsigned long pen)
  1886. {
  1887.   BASE_EXT_DECL
  1888.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1889.   register struct RastPort *a1 __asm("a1") = rp;
  1890.   register unsigned long d0 __asm("d0") = pen;
  1891.   __asm __volatile ("jsr a6@(-0xea)"
  1892.   : /* no output */
  1893.   : "r" (a6), "r" (a1), "r" (d0)
  1894.   : "a0","a1","d0","d1", "memory");
  1895. }
  1896. static __inline ULONG 
  1897. SetSoftStyle (BASE_PAR_DECL struct RastPort *rp,unsigned long style,unsigned long enable)
  1898. {
  1899.   BASE_EXT_DECL
  1900.   register ULONG  _res  __asm("d0");
  1901.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1902.   register struct RastPort *a1 __asm("a1") = rp;
  1903.   register unsigned long d0 __asm("d0") = style;
  1904.   register unsigned long d1 __asm("d1") = enable;
  1905.   __asm __volatile ("jsr a6@(-0x5a)"
  1906.   : "=r" (_res)
  1907.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  1908.   : "a0","a1","d0","d1", "memory");
  1909.   return _res;
  1910. }
  1911. static __inline ULONG 
  1912. SetWriteMask (BASE_PAR_DECL struct RastPort *rp,unsigned long msk)
  1913. {
  1914.   BASE_EXT_DECL
  1915.   register ULONG  _res  __asm("d0");
  1916.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1917.   register struct RastPort *a0 __asm("a0") = rp;
  1918.   register unsigned long d0 __asm("d0") = msk;
  1919.   __asm __volatile ("jsr a6@(-0x3d8)"
  1920.   : "=r" (_res)
  1921.   : "r" (a6), "r" (a0), "r" (d0)
  1922.   : "a0","a1","d0","d1", "memory");
  1923.   return _res;
  1924. }
  1925. static __inline void 
  1926. SortGList (BASE_PAR_DECL struct RastPort *rp)
  1927. {
  1928.   BASE_EXT_DECL
  1929.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1930.   register struct RastPort *a1 __asm("a1") = rp;
  1931.   __asm __volatile ("jsr a6@(-0x96)"
  1932.   : /* no output */
  1933.   : "r" (a6), "r" (a1)
  1934.   : "a0","a1","d0","d1", "memory");
  1935. }
  1936. static __inline void 
  1937. StripFont (BASE_PAR_DECL struct TextFont *font)
  1938. {
  1939.   BASE_EXT_DECL
  1940.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1941.   register struct TextFont *a0 __asm("a0") = font;
  1942.   __asm __volatile ("jsr a6@(-0x336)"
  1943.   : /* no output */
  1944.   : "r" (a6), "r" (a0)
  1945.   : "a0","a1","d0","d1", "memory");
  1946. }
  1947. static __inline void 
  1948. SyncSBitMap (BASE_PAR_DECL struct Layer *layer)
  1949. {
  1950.   BASE_EXT_DECL
  1951.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1952.   register struct Layer *a0 __asm("a0") = layer;
  1953.   __asm __volatile ("jsr a6@(-0x1bc)"
  1954.   : /* no output */
  1955.   : "r" (a6), "r" (a0)
  1956.   : "a0","a1","d0","d1", "memory");
  1957. }
  1958. static __inline LONG 
  1959. Text (BASE_PAR_DECL struct RastPort *rp,STRPTR string,unsigned long count)
  1960. {
  1961.   BASE_EXT_DECL
  1962.   register LONG  _res  __asm("d0");
  1963.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1964.   register struct RastPort *a1 __asm("a1") = rp;
  1965.   register STRPTR a0 __asm("a0") = string;
  1966.   register unsigned long d0 __asm("d0") = count;
  1967.   __asm __volatile ("jsr a6@(-0x3c)"
  1968.   : "=r" (_res)
  1969.   : "r" (a6), "r" (a1), "r" (a0), "r" (d0)
  1970.   : "a0","a1","d0","d1", "memory");
  1971.   return _res;
  1972. }
  1973. static __inline WORD 
  1974. TextExtent (BASE_PAR_DECL struct RastPort *rp,STRPTR string,long count,struct TextExtent *textExtent)
  1975. {
  1976.   BASE_EXT_DECL
  1977.   register WORD  _res  __asm("d0");
  1978.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1979.   register struct RastPort *a1 __asm("a1") = rp;
  1980.   register STRPTR a0 __asm("a0") = string;
  1981.   register long d0 __asm("d0") = count;
  1982.   register struct TextExtent *a2 __asm("a2") = textExtent;
  1983.   __asm __volatile ("jsr a6@(-0x2b2)"
  1984.   : "=r" (_res)
  1985.   : "r" (a6), "r" (a1), "r" (a0), "r" (d0), "r" (a2)
  1986.   : "a0","a1","a2","d0","d1", "memory");
  1987.   return _res;
  1988. }
  1989. static __inline ULONG 
  1990. TextFit (BASE_PAR_DECL struct RastPort *rp,STRPTR string,unsigned long strLen,struct TextExtent *textExtent,struct TextExtent *constrainingExtent,long strDirection,unsigned long constrainingBitWidth,unsigned long constrainingBitHeight)
  1991. {
  1992.   BASE_EXT_DECL
  1993.   register ULONG  _res  __asm("d0");
  1994.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  1995.   register struct RastPort *a1 __asm("a1") = rp;
  1996.   register STRPTR a0 __asm("a0") = string;
  1997.   register unsigned long d0 __asm("d0") = strLen;
  1998.   register struct TextExtent *a2 __asm("a2") = textExtent;
  1999.   register struct TextExtent *a3 __asm("a3") = constrainingExtent;
  2000.   register long d1 __asm("d1") = strDirection;
  2001.   register unsigned long d2 __asm("d2") = constrainingBitWidth;
  2002.   register unsigned long d3 __asm("d3") = constrainingBitHeight;
  2003.   __asm __volatile ("jsr a6@(-0x2b8)"
  2004.   : "=r" (_res)
  2005.   : "r" (a6), "r" (a1), "r" (a0), "r" (d0), "r" (a2), "r" (a3), "r" (d1), "r" (d2), "r" (d3)
  2006.   : "a0","a1","a2","a3","d0","d1","d2","d3", "memory");
  2007.   return _res;
  2008. }
  2009. static __inline WORD 
  2010. TextLength (BASE_PAR_DECL struct RastPort *rp,STRPTR string,unsigned long count)
  2011. {
  2012.   BASE_EXT_DECL
  2013.   register WORD  _res  __asm("d0");
  2014.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2015.   register struct RastPort *a1 __asm("a1") = rp;
  2016.   register STRPTR a0 __asm("a0") = string;
  2017.   register unsigned long d0 __asm("d0") = count;
  2018.   __asm __volatile ("jsr a6@(-0x36)"
  2019.   : "=r" (_res)
  2020.   : "r" (a6), "r" (a1), "r" (a0), "r" (d0)
  2021.   : "a0","a1","d0","d1", "memory");
  2022.   return _res;
  2023. }
  2024. static __inline struct CopList *
  2025. UCopperListInit (BASE_PAR_DECL struct UCopList *uCopList,long n)
  2026. {
  2027.   BASE_EXT_DECL
  2028.   register struct CopList * _res  __asm("d0");
  2029.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2030.   register struct UCopList *a0 __asm("a0") = uCopList;
  2031.   register long d0 __asm("d0") = n;
  2032.   __asm __volatile ("jsr a6@(-0x252)"
  2033.   : "=r" (_res)
  2034.   : "r" (a6), "r" (a0), "r" (d0)
  2035.   : "a0","a1","d0","d1", "memory");
  2036.   return _res;
  2037. }
  2038. static __inline void 
  2039. UnlockLayerRom (BASE_PAR_DECL struct Layer *layer)
  2040. {
  2041.   BASE_EXT_DECL
  2042.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2043.   register struct Layer *a5 __asm("a5") = layer;
  2044.   __asm __volatile ("jsr a6@(-0x1b6)"
  2045.   : /* no output */
  2046.   : "r" (a6), "r" (a5)
  2047.   : "a0","a1","a5","d0","d1", "memory");
  2048. }
  2049. static __inline LONG 
  2050. VBeamPos (BASE_PAR_DECL0)
  2051. {
  2052.   BASE_EXT_DECL
  2053.   register LONG  _res  __asm("d0");
  2054.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2055.   __asm __volatile ("jsr a6@(-0x180)"
  2056.   : "=r" (_res)
  2057.   : "r" (a6)
  2058.   : "a0","a1","d0","d1", "memory");
  2059.   return _res;
  2060. }
  2061. static __inline BOOL 
  2062. VideoControl (BASE_PAR_DECL struct ColorMap *colorMap,struct TagItem *tagarray)
  2063. {
  2064.   BASE_EXT_DECL
  2065.   register BOOL  _res  __asm("d0");
  2066.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2067.   register struct ColorMap *a0 __asm("a0") = colorMap;
  2068.   register struct TagItem *a1 __asm("a1") = tagarray;
  2069.   __asm __volatile ("jsr a6@(-0x2c4)"
  2070.   : "=r" (_res)
  2071.   : "r" (a6), "r" (a0), "r" (a1)
  2072.   : "a0","a1","d0","d1", "memory");
  2073.   return _res;
  2074. }
  2075. #ifndef NO_INLINE_STDARG
  2076. #define VideoControlTags(a0, tags...) \
  2077.   ({ struct TagItem _tags[] = { tags }; VideoControl ((a0), _tags); })
  2078. #endif /* not NO_INLINE_STDARG */
  2079. static __inline void 
  2080. WaitBOVP (BASE_PAR_DECL struct ViewPort *vp)
  2081. {
  2082.   BASE_EXT_DECL
  2083.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2084.   register struct ViewPort *a0 __asm("a0") = vp;
  2085.   __asm __volatile ("jsr a6@(-0x192)"
  2086.   : /* no output */
  2087.   : "r" (a6), "r" (a0)
  2088.   : "a0","a1","d0","d1", "memory");
  2089. }
  2090. static __inline void 
  2091. WaitBlit (BASE_PAR_DECL0)
  2092. {
  2093.   BASE_EXT_DECL
  2094.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2095.   __asm __volatile ("jsr a6@(-0xe4)"
  2096.   : /* no output */
  2097.   : "r" (a6)
  2098.   : "a0","a1","d0","d1", "memory");
  2099. }
  2100. static __inline void 
  2101. WaitTOF (BASE_PAR_DECL0)
  2102. {
  2103.   BASE_EXT_DECL
  2104.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2105.   __asm __volatile ("jsr a6@(-0x10e)"
  2106.   : /* no output */
  2107.   : "r" (a6)
  2108.   : "a0","a1","d0","d1", "memory");
  2109. }
  2110. static __inline WORD 
  2111. WeighTAMatch (BASE_PAR_DECL struct TextAttr *reqTextAttr,struct TextAttr *targetTextAttr,struct TagItem *targetTags)
  2112. {
  2113.   BASE_EXT_DECL
  2114.   register WORD  _res  __asm("d0");
  2115.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2116.   register struct TextAttr *a0 __asm("a0") = reqTextAttr;
  2117.   register struct TextAttr *a1 __asm("a1") = targetTextAttr;
  2118.   register struct TagItem *a2 __asm("a2") = targetTags;
  2119.   __asm __volatile ("jsr a6@(-0x324)"
  2120.   : "=r" (_res)
  2121.   : "r" (a6), "r" (a0), "r" (a1), "r" (a2)
  2122.   : "a0","a1","a2","d0","d1", "memory");
  2123.   return _res;
  2124. }
  2125. #ifndef NO_INLINE_STDARG
  2126. #define WeighTAMatchTags(a0, a1, tags...) \
  2127.   ({ struct TagItem _tags[] = { tags }; WeighTAMatch ((a0), (a1), _tags); })
  2128. #endif /* not NO_INLINE_STDARG */
  2129. static __inline void 
  2130. WriteChunkyPixels (BASE_PAR_DECL struct RastPort *rp,unsigned long xstart,unsigned long ystart,unsigned long xstop,unsigned long ystop,UBYTE *array,long bytesperrow)
  2131. {
  2132.   BASE_EXT_DECL
  2133.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2134.   register struct RastPort *a0 __asm("a0") = rp;
  2135.   register unsigned long d0 __asm("d0") = xstart;
  2136.   register unsigned long d1 __asm("d1") = ystart;
  2137.   register unsigned long d2 __asm("d2") = xstop;
  2138.   register unsigned long d3 __asm("d3") = ystop;
  2139.   register UBYTE *a2 __asm("a2") = array;
  2140.   register long d4 __asm("d4") = bytesperrow;
  2141.   __asm __volatile ("jsr a6@(-0x420)"
  2142.   : /* no output */
  2143.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3), "r" (a2), "r" (d4)
  2144.   : "a0","a1","a2","d0","d1","d2","d3","d4", "memory");
  2145. }
  2146. static __inline LONG 
  2147. WritePixel (BASE_PAR_DECL struct RastPort *rp,long x,long y)
  2148. {
  2149.   BASE_EXT_DECL
  2150.   register LONG  _res  __asm("d0");
  2151.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2152.   register struct RastPort *a1 __asm("a1") = rp;
  2153.   register long d0 __asm("d0") = x;
  2154.   register long d1 __asm("d1") = y;
  2155.   __asm __volatile ("jsr a6@(-0x144)"
  2156.   : "=r" (_res)
  2157.   : "r" (a6), "r" (a1), "r" (d0), "r" (d1)
  2158.   : "a0","a1","d0","d1", "memory");
  2159.   return _res;
  2160. }
  2161. static __inline LONG 
  2162. WritePixelArray8 (BASE_PAR_DECL struct RastPort *rp,unsigned long xstart,unsigned long ystart,unsigned long xstop,unsigned long ystop,UBYTE *array,struct RastPort *temprp)
  2163. {
  2164.   BASE_EXT_DECL
  2165.   register LONG  _res  __asm("d0");
  2166.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2167.   register struct RastPort *a0 __asm("a0") = rp;
  2168.   register unsigned long d0 __asm("d0") = xstart;
  2169.   register unsigned long d1 __asm("d1") = ystart;
  2170.   register unsigned long d2 __asm("d2") = xstop;
  2171.   register unsigned long d3 __asm("d3") = ystop;
  2172.   register UBYTE *a2 __asm("a2") = array;
  2173.   register struct RastPort *a1 __asm("a1") = temprp;
  2174.   __asm __volatile ("jsr a6@(-0x312)"
  2175.   : "=r" (_res)
  2176.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (d3), "r" (a2), "r" (a1)
  2177.   : "a0","a1","a2","d0","d1","d2","d3", "memory");
  2178.   return _res;
  2179. }
  2180. static __inline LONG 
  2181. WritePixelLine8 (BASE_PAR_DECL struct RastPort *rp,unsigned long xstart,unsigned long ystart,unsigned long width,UBYTE *array,struct RastPort *tempRP)
  2182. {
  2183.   BASE_EXT_DECL
  2184.   register LONG  _res  __asm("d0");
  2185.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2186.   register struct RastPort *a0 __asm("a0") = rp;
  2187.   register unsigned long d0 __asm("d0") = xstart;
  2188.   register unsigned long d1 __asm("d1") = ystart;
  2189.   register unsigned long d2 __asm("d2") = width;
  2190.   register UBYTE *a2 __asm("a2") = array;
  2191.   register struct RastPort *a1 __asm("a1") = tempRP;
  2192.   __asm __volatile ("jsr a6@(-0x306)"
  2193.   : "=r" (_res)
  2194.   : "r" (a6), "r" (a0), "r" (d0), "r" (d1), "r" (d2), "r" (a2), "r" (a1)
  2195.   : "a0","a1","a2","d0","d1","d2", "memory");
  2196.   return _res;
  2197. }
  2198. static __inline BOOL 
  2199. XorRectRegion (BASE_PAR_DECL struct Region *region,struct Rectangle *rectangle)
  2200. {
  2201.   BASE_EXT_DECL
  2202.   register BOOL  _res  __asm("d0");
  2203.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2204.   register struct Region *a0 __asm("a0") = region;
  2205.   register struct Rectangle *a1 __asm("a1") = rectangle;
  2206.   __asm __volatile ("jsr a6@(-0x22e)"
  2207.   : "=r" (_res)
  2208.   : "r" (a6), "r" (a0), "r" (a1)
  2209.   : "a0","a1","d0","d1", "memory");
  2210.   return _res;
  2211. }
  2212. static __inline BOOL 
  2213. XorRegionRegion (BASE_PAR_DECL struct Region *srcRegion,struct Region *destRegion)
  2214. {
  2215.   BASE_EXT_DECL
  2216.   register BOOL  _res  __asm("d0");
  2217.   register struct GfxBase* a6 __asm("a6") = BASE_NAME;
  2218.   register struct Region *a0 __asm("a0") = srcRegion;
  2219.   register struct Region *a1 __asm("a1") = destRegion;
  2220.   __asm __volatile ("jsr a6@(-0x26a)"
  2221.   : "=r" (_res)
  2222.   : "r" (a6), "r" (a0), "r" (a1)
  2223.   : "a0","a1","d0","d1", "memory");
  2224.   return _res;
  2225. }
  2226. #undef BASE_EXT_DECL
  2227. #undef BASE_PAR_DECL
  2228. #undef BASE_PAR_DECL0
  2229. #undef BASE_NAME
  2230.  
  2231. __END_DECLS
  2232.  
  2233. #endif /* _INLINE_GRAPHICS_H */
  2234.