1
0
mirror of https://github.com/moparisthebest/curl synced 2025-01-08 20:38:18 -05:00

sasl: use 'unsigned short' to store mechanism

... saves a few bytes of struct size in memory and it only uses
10 bits anyway.

Closes #7045
This commit is contained in:
Daniel Stenberg 2021-05-11 11:11:40 +02:00
parent fa050ffd27
commit a9bc819c89
No known key found for this signature in database
GPG Key ID: 5CC908FDB71E12C2
5 changed files with 13 additions and 12 deletions

View File

@ -58,7 +58,7 @@
static const struct { static const struct {
const char *name; /* Name */ const char *name; /* Name */
size_t len; /* Name length */ size_t len; /* Name length */
unsigned int bit; /* Flag bit */ unsigned short bit; /* Flag bit */
} mechtable[] = { } mechtable[] = {
{ "LOGIN", 5, SASL_MECH_LOGIN }, { "LOGIN", 5, SASL_MECH_LOGIN },
{ "PLAIN", 5, SASL_MECH_PLAIN }, { "PLAIN", 5, SASL_MECH_PLAIN },
@ -128,7 +128,8 @@ void Curl_sasl_cleanup(struct connectdata *conn, unsigned int authused)
* *
* Returns the SASL mechanism token or 0 if no match. * Returns the SASL mechanism token or 0 if no match.
*/ */
unsigned int Curl_sasl_decode_mech(const char *ptr, size_t maxlen, size_t *len) unsigned short Curl_sasl_decode_mech(const char *ptr, size_t maxlen,
size_t *len)
{ {
unsigned int i; unsigned int i;
char c; char c;
@ -173,7 +174,7 @@ CURLcode Curl_sasl_parse_url_auth_option(struct SASL *sasl,
if(!strncmp(value, "*", len)) if(!strncmp(value, "*", len))
sasl->prefmech = SASL_AUTH_DEFAULT; sasl->prefmech = SASL_AUTH_DEFAULT;
else { else {
unsigned int mechbit = Curl_sasl_decode_mech(value, len, &mechlen); unsigned short mechbit = Curl_sasl_decode_mech(value, len, &mechlen);
if(mechbit && mechlen == len) if(mechbit && mechlen == len)
sasl->prefmech |= mechbit; sasl->prefmech |= mechbit;
else else

View File

@ -42,7 +42,7 @@ struct connectdata;
/* Authentication mechanism values */ /* Authentication mechanism values */
#define SASL_AUTH_NONE 0 #define SASL_AUTH_NONE 0
#define SASL_AUTH_ANY ~0U #define SASL_AUTH_ANY 0xffff
#define SASL_AUTH_DEFAULT (SASL_AUTH_ANY & ~SASL_MECH_EXTERNAL) #define SASL_AUTH_DEFAULT (SASL_AUTH_ANY & ~SASL_MECH_EXTERNAL)
/* Authentication mechanism strings */ /* Authentication mechanism strings */
@ -108,9 +108,9 @@ struct SASLproto {
struct SASL { struct SASL {
const struct SASLproto *params; /* Protocol dependent parameters */ const struct SASLproto *params; /* Protocol dependent parameters */
saslstate state; /* Current machine state */ saslstate state; /* Current machine state */
unsigned int authmechs; /* Accepted authentication mechanisms */ unsigned short authmechs; /* Accepted authentication mechanisms */
unsigned int prefmech; /* Preferred authentication mechanism */ unsigned short prefmech; /* Preferred authentication mechanism */
unsigned int authused; /* Auth mechanism used for the connection */ unsigned short authused; /* Auth mechanism used for the connection */
bool resetprefs; /* For URL auth option parsing. */ bool resetprefs; /* For URL auth option parsing. */
bool mutual_auth; /* Mutual authentication enabled (GSSAPI only) */ bool mutual_auth; /* Mutual authentication enabled (GSSAPI only) */
bool force_ir; /* Protocol always supports initial response */ bool force_ir; /* Protocol always supports initial response */
@ -126,8 +126,8 @@ struct SASL {
void Curl_sasl_cleanup(struct connectdata *conn, unsigned int authused); void Curl_sasl_cleanup(struct connectdata *conn, unsigned int authused);
/* Convert a mechanism name to a token */ /* Convert a mechanism name to a token */
unsigned int Curl_sasl_decode_mech(const char *ptr, unsigned short Curl_sasl_decode_mech(const char *ptr,
size_t maxlen, size_t *len); size_t maxlen, size_t *len);
/* Parse the URL login options */ /* Parse the URL login options */
CURLcode Curl_sasl_parse_url_auth_option(struct SASL *sasl, CURLcode Curl_sasl_parse_url_auth_option(struct SASL *sasl,

View File

@ -919,7 +919,7 @@ static CURLcode imap_state_capability_resp(struct Curl_easy *data,
/* Do we have a SASL based authentication mechanism? */ /* Do we have a SASL based authentication mechanism? */
else if(wordlen > 5 && !memcmp(line, "AUTH=", 5)) { else if(wordlen > 5 && !memcmp(line, "AUTH=", 5)) {
size_t llen; size_t llen;
unsigned int mechbit; unsigned short mechbit;
line += 5; line += 5;
wordlen -= 5; wordlen -= 5;

View File

@ -709,7 +709,7 @@ static CURLcode pop3_state_capa_resp(struct Curl_easy *data, int pop3code,
for(;;) { for(;;) {
size_t llen; size_t llen;
size_t wordlen; size_t wordlen;
unsigned int mechbit; unsigned short mechbit;
while(len && while(len &&
(*line == ' ' || *line == '\t' || (*line == ' ' || *line == '\t' ||

View File

@ -894,7 +894,7 @@ static CURLcode smtp_state_ehlo_resp(struct Curl_easy *data,
for(;;) { for(;;) {
size_t llen; size_t llen;
size_t wordlen; size_t wordlen;
unsigned int mechbit; unsigned short mechbit;
while(len && while(len &&
(*line == ' ' || *line == '\t' || (*line == ' ' || *line == '\t' ||