mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-06 13:23:18 +00:00
0671cc1048
Add support for AP bus adapter config and deconfig to the sclp core code. The code is statically build into the kernel when ZCRYPT is configured either as module or with static support. This is the base functionality for having configure/deconfigure support in the AP bus and card code. Another patch will exploit this soon. Signed-off-by: Harald Freudenberger <freude@linux.ibm.com> Suggested-by: Pierre Morel <pmorel@linux.ibm.com> Signed-off-by: Vasily Gorbik <gor@linux.ibm.com>
64 lines
1.3 KiB
C
64 lines
1.3 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* s390 crypto adapter related sclp functions.
|
|
*
|
|
* Copyright IBM Corp. 2020
|
|
*/
|
|
#define KMSG_COMPONENT "sclp_cmd"
|
|
#define pr_fmt(fmt) KMSG_COMPONENT ": " fmt
|
|
|
|
#include <linux/export.h>
|
|
#include <linux/slab.h>
|
|
#include <asm/sclp.h>
|
|
#include "sclp.h"
|
|
|
|
#define SCLP_CMDW_CONFIGURE_AP 0x001f0001
|
|
#define SCLP_CMDW_DECONFIGURE_AP 0x001e0001
|
|
|
|
struct ap_cfg_sccb {
|
|
struct sccb_header header;
|
|
} __packed;
|
|
|
|
static int do_ap_configure(sclp_cmdw_t cmd, u32 apid)
|
|
{
|
|
struct ap_cfg_sccb *sccb;
|
|
int rc;
|
|
|
|
if (!SCLP_HAS_AP_RECONFIG)
|
|
return -EOPNOTSUPP;
|
|
|
|
sccb = (struct ap_cfg_sccb *) get_zeroed_page(GFP_KERNEL | GFP_DMA);
|
|
if (!sccb)
|
|
return -ENOMEM;
|
|
|
|
sccb->header.length = PAGE_SIZE;
|
|
cmd |= (apid & 0xFF) << 8;
|
|
rc = sclp_sync_request(cmd, sccb);
|
|
if (rc)
|
|
goto out;
|
|
switch (sccb->header.response_code) {
|
|
case 0x0020: case 0x0120: case 0x0440: case 0x0450:
|
|
break;
|
|
default:
|
|
pr_warn("configure AP adapter %u failed: cmd=0x%08x response=0x%04x\n",
|
|
apid, cmd, sccb->header.response_code);
|
|
rc = -EIO;
|
|
break;
|
|
}
|
|
out:
|
|
free_page((unsigned long) sccb);
|
|
return rc;
|
|
}
|
|
|
|
int sclp_ap_configure(u32 apid)
|
|
{
|
|
return do_ap_configure(SCLP_CMDW_CONFIGURE_AP, apid);
|
|
}
|
|
EXPORT_SYMBOL(sclp_ap_configure);
|
|
|
|
int sclp_ap_deconfigure(u32 apid)
|
|
{
|
|
return do_ap_configure(SCLP_CMDW_DECONFIGURE_AP, apid);
|
|
}
|
|
EXPORT_SYMBOL(sclp_ap_deconfigure);
|