1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0-only 2*4882a593Smuzhiyun /****************************************************************************** 3*4882a593Smuzhiyun ******************************************************************************* 4*4882a593Smuzhiyun ** 5*4882a593Smuzhiyun ** Copyright (C) 2005-2008 Red Hat, Inc. All rights reserved. 6*4882a593Smuzhiyun ** 7*4882a593Smuzhiyun ** 8*4882a593Smuzhiyun ******************************************************************************* 9*4882a593Smuzhiyun ******************************************************************************/ 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #include "dlm_internal.h" 12*4882a593Smuzhiyun #include "rcom.h" 13*4882a593Smuzhiyun #include "util.h" 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun #define DLM_ERRNO_EDEADLK 35 16*4882a593Smuzhiyun #define DLM_ERRNO_EBADR 53 17*4882a593Smuzhiyun #define DLM_ERRNO_EBADSLT 57 18*4882a593Smuzhiyun #define DLM_ERRNO_EPROTO 71 19*4882a593Smuzhiyun #define DLM_ERRNO_EOPNOTSUPP 95 20*4882a593Smuzhiyun #define DLM_ERRNO_ETIMEDOUT 110 21*4882a593Smuzhiyun #define DLM_ERRNO_EINPROGRESS 115 22*4882a593Smuzhiyun header_out(struct dlm_header * hd)23*4882a593Smuzhiyunstatic void header_out(struct dlm_header *hd) 24*4882a593Smuzhiyun { 25*4882a593Smuzhiyun hd->h_version = cpu_to_le32(hd->h_version); 26*4882a593Smuzhiyun hd->h_lockspace = cpu_to_le32(hd->h_lockspace); 27*4882a593Smuzhiyun hd->h_nodeid = cpu_to_le32(hd->h_nodeid); 28*4882a593Smuzhiyun hd->h_length = cpu_to_le16(hd->h_length); 29*4882a593Smuzhiyun } 30*4882a593Smuzhiyun header_in(struct dlm_header * hd)31*4882a593Smuzhiyunstatic void header_in(struct dlm_header *hd) 32*4882a593Smuzhiyun { 33*4882a593Smuzhiyun hd->h_version = le32_to_cpu(hd->h_version); 34*4882a593Smuzhiyun hd->h_lockspace = le32_to_cpu(hd->h_lockspace); 35*4882a593Smuzhiyun hd->h_nodeid = le32_to_cpu(hd->h_nodeid); 36*4882a593Smuzhiyun hd->h_length = le16_to_cpu(hd->h_length); 37*4882a593Smuzhiyun } 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun /* higher errno values are inconsistent across architectures, so select 40*4882a593Smuzhiyun one set of values for on the wire */ 41*4882a593Smuzhiyun to_dlm_errno(int err)42*4882a593Smuzhiyunstatic int to_dlm_errno(int err) 43*4882a593Smuzhiyun { 44*4882a593Smuzhiyun switch (err) { 45*4882a593Smuzhiyun case -EDEADLK: 46*4882a593Smuzhiyun return -DLM_ERRNO_EDEADLK; 47*4882a593Smuzhiyun case -EBADR: 48*4882a593Smuzhiyun return -DLM_ERRNO_EBADR; 49*4882a593Smuzhiyun case -EBADSLT: 50*4882a593Smuzhiyun return -DLM_ERRNO_EBADSLT; 51*4882a593Smuzhiyun case -EPROTO: 52*4882a593Smuzhiyun return -DLM_ERRNO_EPROTO; 53*4882a593Smuzhiyun case -EOPNOTSUPP: 54*4882a593Smuzhiyun return -DLM_ERRNO_EOPNOTSUPP; 55*4882a593Smuzhiyun case -ETIMEDOUT: 56*4882a593Smuzhiyun return -DLM_ERRNO_ETIMEDOUT; 57*4882a593Smuzhiyun case -EINPROGRESS: 58*4882a593Smuzhiyun return -DLM_ERRNO_EINPROGRESS; 59*4882a593Smuzhiyun } 60*4882a593Smuzhiyun return err; 61*4882a593Smuzhiyun } 62*4882a593Smuzhiyun from_dlm_errno(int err)63*4882a593Smuzhiyunstatic int from_dlm_errno(int err) 64*4882a593Smuzhiyun { 65*4882a593Smuzhiyun switch (err) { 66*4882a593Smuzhiyun case -DLM_ERRNO_EDEADLK: 67*4882a593Smuzhiyun return -EDEADLK; 68*4882a593Smuzhiyun case -DLM_ERRNO_EBADR: 69*4882a593Smuzhiyun return -EBADR; 70*4882a593Smuzhiyun case -DLM_ERRNO_EBADSLT: 71*4882a593Smuzhiyun return -EBADSLT; 72*4882a593Smuzhiyun case -DLM_ERRNO_EPROTO: 73*4882a593Smuzhiyun return -EPROTO; 74*4882a593Smuzhiyun case -DLM_ERRNO_EOPNOTSUPP: 75*4882a593Smuzhiyun return -EOPNOTSUPP; 76*4882a593Smuzhiyun case -DLM_ERRNO_ETIMEDOUT: 77*4882a593Smuzhiyun return -ETIMEDOUT; 78*4882a593Smuzhiyun case -DLM_ERRNO_EINPROGRESS: 79*4882a593Smuzhiyun return -EINPROGRESS; 80*4882a593Smuzhiyun } 81*4882a593Smuzhiyun return err; 82*4882a593Smuzhiyun } 83*4882a593Smuzhiyun dlm_message_out(struct dlm_message * ms)84*4882a593Smuzhiyunvoid dlm_message_out(struct dlm_message *ms) 85*4882a593Smuzhiyun { 86*4882a593Smuzhiyun header_out(&ms->m_header); 87*4882a593Smuzhiyun 88*4882a593Smuzhiyun ms->m_type = cpu_to_le32(ms->m_type); 89*4882a593Smuzhiyun ms->m_nodeid = cpu_to_le32(ms->m_nodeid); 90*4882a593Smuzhiyun ms->m_pid = cpu_to_le32(ms->m_pid); 91*4882a593Smuzhiyun ms->m_lkid = cpu_to_le32(ms->m_lkid); 92*4882a593Smuzhiyun ms->m_remid = cpu_to_le32(ms->m_remid); 93*4882a593Smuzhiyun ms->m_parent_lkid = cpu_to_le32(ms->m_parent_lkid); 94*4882a593Smuzhiyun ms->m_parent_remid = cpu_to_le32(ms->m_parent_remid); 95*4882a593Smuzhiyun ms->m_exflags = cpu_to_le32(ms->m_exflags); 96*4882a593Smuzhiyun ms->m_sbflags = cpu_to_le32(ms->m_sbflags); 97*4882a593Smuzhiyun ms->m_flags = cpu_to_le32(ms->m_flags); 98*4882a593Smuzhiyun ms->m_lvbseq = cpu_to_le32(ms->m_lvbseq); 99*4882a593Smuzhiyun ms->m_hash = cpu_to_le32(ms->m_hash); 100*4882a593Smuzhiyun ms->m_status = cpu_to_le32(ms->m_status); 101*4882a593Smuzhiyun ms->m_grmode = cpu_to_le32(ms->m_grmode); 102*4882a593Smuzhiyun ms->m_rqmode = cpu_to_le32(ms->m_rqmode); 103*4882a593Smuzhiyun ms->m_bastmode = cpu_to_le32(ms->m_bastmode); 104*4882a593Smuzhiyun ms->m_asts = cpu_to_le32(ms->m_asts); 105*4882a593Smuzhiyun ms->m_result = cpu_to_le32(to_dlm_errno(ms->m_result)); 106*4882a593Smuzhiyun } 107*4882a593Smuzhiyun dlm_message_in(struct dlm_message * ms)108*4882a593Smuzhiyunvoid dlm_message_in(struct dlm_message *ms) 109*4882a593Smuzhiyun { 110*4882a593Smuzhiyun header_in(&ms->m_header); 111*4882a593Smuzhiyun 112*4882a593Smuzhiyun ms->m_type = le32_to_cpu(ms->m_type); 113*4882a593Smuzhiyun ms->m_nodeid = le32_to_cpu(ms->m_nodeid); 114*4882a593Smuzhiyun ms->m_pid = le32_to_cpu(ms->m_pid); 115*4882a593Smuzhiyun ms->m_lkid = le32_to_cpu(ms->m_lkid); 116*4882a593Smuzhiyun ms->m_remid = le32_to_cpu(ms->m_remid); 117*4882a593Smuzhiyun ms->m_parent_lkid = le32_to_cpu(ms->m_parent_lkid); 118*4882a593Smuzhiyun ms->m_parent_remid = le32_to_cpu(ms->m_parent_remid); 119*4882a593Smuzhiyun ms->m_exflags = le32_to_cpu(ms->m_exflags); 120*4882a593Smuzhiyun ms->m_sbflags = le32_to_cpu(ms->m_sbflags); 121*4882a593Smuzhiyun ms->m_flags = le32_to_cpu(ms->m_flags); 122*4882a593Smuzhiyun ms->m_lvbseq = le32_to_cpu(ms->m_lvbseq); 123*4882a593Smuzhiyun ms->m_hash = le32_to_cpu(ms->m_hash); 124*4882a593Smuzhiyun ms->m_status = le32_to_cpu(ms->m_status); 125*4882a593Smuzhiyun ms->m_grmode = le32_to_cpu(ms->m_grmode); 126*4882a593Smuzhiyun ms->m_rqmode = le32_to_cpu(ms->m_rqmode); 127*4882a593Smuzhiyun ms->m_bastmode = le32_to_cpu(ms->m_bastmode); 128*4882a593Smuzhiyun ms->m_asts = le32_to_cpu(ms->m_asts); 129*4882a593Smuzhiyun ms->m_result = from_dlm_errno(le32_to_cpu(ms->m_result)); 130*4882a593Smuzhiyun } 131*4882a593Smuzhiyun dlm_rcom_out(struct dlm_rcom * rc)132*4882a593Smuzhiyunvoid dlm_rcom_out(struct dlm_rcom *rc) 133*4882a593Smuzhiyun { 134*4882a593Smuzhiyun header_out(&rc->rc_header); 135*4882a593Smuzhiyun 136*4882a593Smuzhiyun rc->rc_type = cpu_to_le32(rc->rc_type); 137*4882a593Smuzhiyun rc->rc_result = cpu_to_le32(rc->rc_result); 138*4882a593Smuzhiyun rc->rc_id = cpu_to_le64(rc->rc_id); 139*4882a593Smuzhiyun rc->rc_seq = cpu_to_le64(rc->rc_seq); 140*4882a593Smuzhiyun rc->rc_seq_reply = cpu_to_le64(rc->rc_seq_reply); 141*4882a593Smuzhiyun } 142*4882a593Smuzhiyun dlm_rcom_in(struct dlm_rcom * rc)143*4882a593Smuzhiyunvoid dlm_rcom_in(struct dlm_rcom *rc) 144*4882a593Smuzhiyun { 145*4882a593Smuzhiyun header_in(&rc->rc_header); 146*4882a593Smuzhiyun 147*4882a593Smuzhiyun rc->rc_type = le32_to_cpu(rc->rc_type); 148*4882a593Smuzhiyun rc->rc_result = le32_to_cpu(rc->rc_result); 149*4882a593Smuzhiyun rc->rc_id = le64_to_cpu(rc->rc_id); 150*4882a593Smuzhiyun rc->rc_seq = le64_to_cpu(rc->rc_seq); 151*4882a593Smuzhiyun rc->rc_seq_reply = le64_to_cpu(rc->rc_seq_reply); 152*4882a593Smuzhiyun } 153