Wow!

I used to think that I was pretty sharp on the AS/400 (and the S/38 before 
that, and the S/3
before that).  I used to think that I could do anything... well, almost... 
certainly a lot more
than most nine-to-fivers that just want to write the report the boss needs so 
they can go
home.  I used to think my contribution was pretty awesome.  Maybe that's all 
because ... I
used to think.  :)

You guys are AWESOME!  Thanks, Dave and Simon and the others for reminding me of
what I so love about my job!  And for a gentle reminder of the cost of sitting 
back on one's
laurels (what's a laurel?) and enjoying the "awesome" status that may well be a 
figment of
one's own imagination!  :)

Yeah, I'm still comfortable with my knowledge of the systems and thankful for a 
wonderful
mind for things technical.  Now if I can just get back home to my iSeries 
system and do
some real playing.  But first, there's this report that the boss needs to have 
by 5:00.....
--
Qiu Min & Dennis Lovelady
mail: dennis@lovelady.com
URL:  http://www.lovelady.com
ICQ:  5734860
--
"Because of our taping schedule, this show will take place three weeks after 
you see it."
  -- sportscaster Don Gillis


On 19 Jan 2002 at 7:28, Dave McKenzie wrote:

> On Friday 18 January 2002 04:36 pm, Simon Coulter wrote:
> > Hello Dave,
> >
> > I want to know more . . .
>
> See interspersed comments below.
>
> >
> > I was playing with this yesterday as a result of Dennis' question.
> > I used TRCJOB to determine that QCADRV calls QMHSNDPM to send the
> > command messages.  I used SST to determine that QMHSNDPM changes the
> > external message types (e.g., *ESCAPE) to internal forms (e.g.,
> > ESCP) and that QMHSNDPM would support a CMD message (but not *CMD).
> > I also determined that CMD messages must be impromptu messages
> > (verified by CPF24C4).
> >
> > I set a breakpoint in QMHSNDPM at '/0001' and then started DMPJOB
> > for QMHSNDPM and QCADRV.  From the contents of program storage (see
> > below) I could see that QCADRV uses PREV for the message queue, *
> > for the call stack entry, and CMD for the message type but I could
> > not find the message text. After reading your code I can see some of
> > the other values (which I have underlined).
> >
> > 00000C5A 00500000 00000000 00000000   <== Junk ???
> > 80000000 00000000 D1D80C68 CD001630   <== Pointer to something (msg
> > text) 80000000 00000000 DB2E5DF1 EC001000   <== Pointer to something
> > ~~~~~~~~~~ 004ED7E6 00000000 00000000 00000000   <== Junk ???
> > 00000000 00000000 00000000 00000000 00000000 00000000 00000000
> > 00000000 D7D9C5E5 5C404040 40404040 404016F9   PREV* 00000000
> > 00000000 00000000 00000000 20000000 00000000 0BC3D4C4 405DFF40
> >            CMD
> >                              ~~~~
> > F1F1F1F1 F1F1F1F1 F1F1F1F1 F1F1F1F1   <== Junk from here on?
> > F1F1F1F1 F1F1F1F1 F1F1F1F1 F1F1F1F1
> > F1F1F1F1 F1F10001 FFFFFFFF F1F1F1F1
> >              ~~~~ ~~~~~~~~
> > F1F1F1F1 F1F1F1F1 F1F1F1F1 F1F1F1F1
> > F0F0F0F0 F0F0F0F0 F0F0F0F0 F0F0F0F0
> > F0F0F0F0 F0F0F0F0 F0F0F0F0 F0F0F0F0
> > F0F0F0F0 F0F0F0F0 F0F0F0F0 F0F0F0F0
> > (and lots more of these char 1's and 0's)
> >
> > I was expecting QCADRV to obey the documented QMHSNDPM interface and
> > tried many variations of:
> >
> >     CALL PGM(QMHSNDPM) PARM('       ' '                    ' +
> >             '  300 - A TRACED LINE' X'00000016' 'CMD       ' +
> >             '*         ' 'PREV' '     ' X'0000000000000000')
> >
> > and of course received the expected error messages about CMD not a
> > valid message type and problems with PREV (for which I also tried
> > X'00000001'). I thought it might be that command messages must be
> > sent from QCADRV and so created my own program called that (owned by
> > QSYS and system state) but that didn't work (and wouldn't really be
> > much use if it had worked).  I tried a number of other things too
> > but they all proved fruitless.
> >
> > What made you twig to the single parameter interface?
>
> I guess "twig" is Aussie for "grok?" :-)  Well, I cheated.  I had an
> old defunct MI pgm lying around, dated 1994, which sent a scope msg
> using the 1-parm interface.  I can't remember '94 too well (can't even
> remember what I had for dinner last night), but I think I found it by
> examining the disassembled machine code of some QSYS pgm that calls
> QMHSNDPM (this was on CISC).  I do recall seeing the code in QMHSNDPM
> that determines whether its caller is system state by looking at a bit
> in the ICB.
>
> > I would expect a
> > single parameter to be contiguous storage but the dump above shows
> > much junk between the parameters (nulls, 1's, and 0's).  I see that
> > your structure has gaps which correspond to the 'junk' so it is
> > contiguous and maps perfectly to the dump shown above.  What made
> > you ignore all the nulls and character 1's and 0's among the real
> > values (other than they just look wierd)?
>
> I think the space between the significant stuff is other fields that
> aren't used in this instance.  For example, when sending a scope msg,
> there's a pointer to a 4-byte msg key at offset x'40'.  I'm guessing
> the 'junk' is un-initialized storage.  I just used my trusty Occam's
> razor: started with all hex 0's, adding the fields that were obviously
> needed and quit when it worked.  (That and the QSYS pgm setting only
> those fields.)  I guess this is the exact reverse of Michaelangelo's
> technique--starting with a marble block and removing anything that
> doesn't look like a statue.
>
> >
> > What made you realise a pointer to the message text was passed?  (I
> > should have followed those pointers ...)
>
> I followed those pointers :-) til I found something that looked like a
> cmd string.
>
> >
> > Why did you call the X'5DFF' value SPMSGID when it's not a valid
> > message ID and is only 2-bytes long?
>
> I changed it to x'0000' and got CPF2499 "Message identifer xxxxxxx not
> allowed" where xxxxxxx is a very attractive reverse-image rectangle.
> However, I couldn't find any CPF5DFF or MCH5DFF, or even 93xx in
> QCPFMSG.
>
> >
> > How did you know the X'0001' value was a parameter value when the
> > field name SPB7 indicates its purpose is unknown?
>
> I changed it to x'0000' and it worked fine, but the '94 pgm had
> x'0001' so I left it.  The QSYS pgm passed x'0001' but I don't know
> what it is.
>
> >
> > How did you know the two X'FFFF' fields are CSSID and INVocation
> > OFfset? (Although offset doesn't make much sense since the relative
> > invocation entry is PREV in my dump and SAME in your code.)  Both of
> > which are probably BIN(2) rather than CHAR(2).
>
> Changing the CCSID field to x'0000' gets CPF247E "CCSID -1610612736 is
> not valid."  But how they got -1610612736 (x'A0000000') out of x'0000'
> I don't know.
>
> Changing SPINVOF to x'ABCD' gets MCH4426 "Invocation offset outside
> range of current stack."
>
> >
> > I, and probably others, would find a description of your
> > investigative process helpful.  I guess the part I'm missing is how
> > you determined the structure of the single parameter because the
> > field names you use make it obvious that you know what most of them
> > are for yet the data itself only helps with determining the purpose
> > of three fields -- please don't tell me you just looked at the CPF
> > microfiche, or used the CPF Data Areas manual :)
>
> No, as Linus would say, "Microfiche?  We don't need no steenking
> Microfiche!!"
>
> >
> > Regards,
> > Simon Coulter.
> >
> > --------------------------------------------------------------------
> >    FlyByNight Software         AS/400 Technical Specialists
> >    http://www.flybynight.com.au/
> >
> >    Phone: +61 3 9419 0175   Mobile: +61 0411 091 400        /"\ Fax:
> >      +61 3 9419 0175   mailto: shc@flybynight.com.au   \ /
> >                                   X
> >                  ASCII Ribbon campaign against HTML E-Mail  / \
> > --------------------------------------------------------------------
>
> --Dave
> _______________________________________________
> This is the MI Programming on the AS400 / iSeries (MI400) mailing list
> To post a message email: MI400@midrange.com To subscribe, unsubscribe,
> or change list options, visit:
> http://lists.midrange.com/cgi-bin/listinfo/mi400 or email:
> MI400-request@midrange.com Before posting, please take a moment to
> review the archives at http://archive.midrange.com/mi400.
>




As an Amazon Associate we earn from qualifying purchases.

This thread ...

Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.