Jump to content

starfighter

Members
  • Content Count

    5
  • Joined

  • Last visited

Community Reputation

0 Neutral

About starfighter

  • Rank
    Combat Commando
  1. Hi Tebe, thanks, updating the array after initialisation is is exactly what I did as a workaround. So I assume, there is no other way than doing this. Thank you for the clarification!
  2. Ah, okay, thanks for checking! I know about Graph2Font! it is also an awesome tool, but I haven't used it yet. But I have put it on my list of cool Atari stuff to check out If anyone is interested, I have compiled the latest versions of Mad Pascal and MADS for Mac OS: Mad Pascal 1.5.8: https://github.com/starfighter06/Mad-Pascal-for-Mac-OS MADS 2.0.8: https://github.com/starfighter06/MADS-for-Mac-OS I did it for my own purposes as I am a Mac OS user, but maybe it is useful to other people as well.
  3. Hello Tebe, awesome! That solved both problems at once, thank you very much! Sometimes the solution is so simple If I remember correctly I had the DL arrays once defined as constants, but then moved them to var, bc I thought about changing them on the fly. I don't know what other developers think, but generally being able to specify certain memory locations or border alignments for arrays, variables, procedures, might be a useful native feature for Mad Pascal or what do you think? By the way, do you know, why the other issue occured when the array was defined as variable (i.e. that the pointer after the JVB command was not stored during array initialisation): PlayfieldDisplayList: array [0..98] of byte = ( ... ... $41, lo(word(@PlayfieldDisplayList)), hi (word(@PlayfieldDisplayList)) //JVB: Wait for vertical blank + jump to Display List Memory Location ); How should this be handled properly other than just overwriting it afterwards? Many thanks and kind regards, starfighter
  4. Thank you for your answers! It would be good if I could reserve a specific memory area for the array, but how can I achive this in Mad Pascal? The array and its content is defined in the var section of the code and I would like to leave it this way for code readibility reasons. Of course, I could define the DL and the memory location in assembler and include the code via the ASM tag. I have done this e.g. for including a character font file. But if there is a cleaner way to do all this in Mad Pascal directly, this would be my preferred choice.
  5. Hello, I am a long time Atari-User (my first computer was the 800XL back in 1985) and a retro computing fan. It is very fascinating to see that new technology and software is still being developed for these machines. I am especially impressed by tools like MADS/WUDSN IDE and Mad Pascal. Therefore I decided to start learning Mad Pascal (with a little bit of Assembler). I am not a very active forum writer in general, it is not my thing really, but I decided to write my very first post nevertheless. My question is related to memory management in MadPascal. I would like to understand if there is a smart or "clean" way to cover specific memory requirements of the Atari, such as 1K-Border restrictions for Display Lists or 4K-Border restrictions for screen memory? For example, I am thinking of something similar like the ".align" directive in MADS? Here is an example of my problem: Imagine a simple display list configured as an array: //Custom Display List for Playfield Screen PlayfieldDisplayList: array [0..98] of byte = ( $70, $70, $70, //3 x 8 blank lines (24 Scanlines) $42, lo(PlayfieldHeaderMem), hi(PlayfieldHeaderMem), //2 x Mode 2: Playfield Header (16 Scanlines) $02, $4D, lo(PlayfieldGraphicsMem), hi(PlayfieldGraphicsMem), //84 x Mode D: Playfield (168 Scanlines) $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $0D, $42, lo(PlayfieldFooterMem), hi(PlayfieldFooterMem), //1 x Mode 2: Playfield Footer (8 Scanlines) $41, lo(word(@PlayfieldDisplayList)), hi (word(@PlayfieldDisplayList)) //JVB: Wait for vertical blank + jump to Display List Memory Location ); I am facing in my program now two problems: 1. The array was placed into the memory at location $57DD, thus breaking the 1K-boundary at $5800. 2. The address for the JVB is not correctly set to the start address of the display list. Maybe due to a "chicken egg problem", that the array does not know its own location at initialization? For reference, see the memory dump of the array: I can surely find some workarounds for these issues, especially the second one, by just updating the last two array items with the correct memory location for the JVB AFTER the initialization of the whole array. I have to think about the first issue yet. Probably by just reorganizing or growing the code, the problem might get solved by itself. However, I am curious if there is a better way to manage the memory in MadPascal without "hacking" or hardcoding memory locations into the code? Many thanks in advance and kind regards, starfighter
×
×
  • Create New...