patch-2.2.14 linux/arch/s390/kernel/cpcmd.c
Next file: linux/arch/s390/kernel/cpcmd.h
Previous file: linux/arch/s390/kernel/bitmap.S
Back to the patch index
Back to the overall index
- Lines: 54
- Date:
Tue Jan 4 10:12:12 2000
- Orig file:
v2.2.13/linux/arch/s390/kernel/cpcmd.c
- Orig date:
Wed Dec 31 16:00:00 1969
diff -u --recursive --new-file v2.2.13/linux/arch/s390/kernel/cpcmd.c linux/arch/s390/kernel/cpcmd.c
@@ -0,0 +1,53 @@
+/*
+ * arch/s390/kernel/cpcmd.c
+ *
+ * S390 version
+ * Copyright (C) 1999 IBM Deutschland Entwicklung GmbH, IBM Corporation
+ * Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com),
+ */
+
+#include <linux/stddef.h>
+#include <asm/string.h>
+#include <asm/ebcdic.h>
+
+void cpcmd(char *cmd, char *response, int rlen)
+{
+ const int mask = 0x40000000L;
+ char obuffer[128];
+ int olen;
+
+ olen = strlen(cmd);
+ strcpy(obuffer, cmd);
+ ASCEBC(obuffer,olen);
+
+ if (response != NULL && rlen > 0) {
+ asm volatile ("LRA 2,0(0,%0)\n\t"
+ "LR 4,%1\n\t"
+ "O 4,%4\n\t"
+ "LRA 3,0(0,%2)\n\t"
+ "LR 5,%3\n\t"
+ ".long 0x83240008 # Diagnose 83\n\t"
+ : /* no output */
+ : "a" (obuffer), "d" (olen),
+ "a" (response), "d" (rlen), "m" (mask)
+ : "2", "3", "4", "5" );
+ EBCASC(response, rlen);
+ } else {
+ asm volatile ("LRA 2,0(0,%0)\n\t"
+ "LR 3,%1\n\t"
+ ".long 0x83230008 # Diagnose 83\n\t"
+ : /* no output */
+ : "a" (obuffer), "d" (olen)
+ : "2", "3" );
+ }
+}
+
+int sys_msgcp(char *str)
+{
+ char buffer[256];
+
+ sprintf(buffer, "MSG * %s", str);
+ cpcmd(buffer, NULL, 0);
+ cpcmd("STOP", NULL, 0);
+}
+
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)