From 1d389f0fa49b7a422de1e01d8cd3b2f276d5c2c6 Mon Sep 17 00:00:00 2001 From: rillig Date: Sat, 8 Jul 2023 12:45:43 +0000 Subject: [PATCH] lint: warn about conversion from 128-bit to smaller integer types --- tests/usr.bin/xlint/lint1/platform_lp64.c | 5 +++-- usr.bin/xlint/lint1/tree.c | 7 +++---- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/tests/usr.bin/xlint/lint1/platform_lp64.c b/tests/usr.bin/xlint/lint1/platform_lp64.c index 6b981f83e006..8c0ea5abbee5 100644 --- a/tests/usr.bin/xlint/lint1/platform_lp64.c +++ b/tests/usr.bin/xlint/lint1/platform_lp64.c @@ -1,4 +1,4 @@ -/* $NetBSD: platform_lp64.c,v 1.6 2023/07/08 12:42:11 rillig Exp $ */ +/* $NetBSD: platform_lp64.c,v 1.7 2023/07/08 12:45:43 rillig Exp $ */ # 3 "platform_lp64.c" /* @@ -39,7 +39,8 @@ convert_unsigned_char_to_size_t(unsigned char uc) void convert_128(void) { - /* TODO: Warn about 128-bit types as well. */ + /* expect+1: warning: conversion from '__int128_t' to 'int' may lose accuracy [132] */ s32 = s128; + /* expect+1: warning: conversion from '__uint128_t' to 'unsigned int' may lose accuracy [132] */ u32 = u128; } diff --git a/usr.bin/xlint/lint1/tree.c b/usr.bin/xlint/lint1/tree.c index d723d631bc79..5bda4bf4e629 100644 --- a/usr.bin/xlint/lint1/tree.c +++ b/usr.bin/xlint/lint1/tree.c @@ -1,4 +1,4 @@ -/* $NetBSD: tree.c,v 1.551 2023/07/08 12:07:21 rillig Exp $ */ +/* $NetBSD: tree.c,v 1.552 2023/07/08 12:45:43 rillig Exp $ */ /* * Copyright (c) 1994, 1995 Jochen Pohl @@ -37,7 +37,7 @@ #include #if defined(__RCSID) -__RCSID("$NetBSD: tree.c,v 1.551 2023/07/08 12:07:21 rillig Exp $"); +__RCSID("$NetBSD: tree.c,v 1.552 2023/07/08 12:45:43 rillig Exp $"); #endif #include @@ -3447,8 +3447,7 @@ convert_integer_from_integer(op_t op, int arg, tspec_t nt, tspec_t ot, if (aflag > 0 && portable_rank_cmp(nt, ot) < 0 && - (ot == LONG || ot == ULONG || ot == LLONG || ot == ULLONG || - aflag > 1) && + (portable_rank_cmp(ot, LONG) >= 0 || aflag > 1) && // XXX: The portable_rank_cmp above aims at portable mode, // independent of the current platform, while can_represent acts // on the actual types from the current platform. This mix is